SpringSecurit鹽值加密的密碼驗證以及強密碼驗證過程
更新時間:2024年10月10日 10:37:58 作者:思祺班
在密碼加密過程中,鹽值的使用可以增強密碼的安全性,如果忘記存儲鹽值,將無法驗證密碼,強密碼應包含數(shù)字、字母和特殊字符,長度應在8到30位之間,以提高賬戶安全
SpringSecurit鹽值加密的密碼驗證及強密碼驗證
1、有的時候我們鹽值加密的時候沒有存入鹽值
值存入了密碼,然后怎么樣驗證這個密碼呢
以下代碼展示:
PasswordEncoder pe = new BCryptPasswordEncoder(); //比較密碼 //pe.matches (“前端存過來的密碼記得是沒有加密的”,“在數(shù)據(jù)中存儲的加密的密碼”) ; boolean matches = pe.matches (changePwdDTO.getOldPassword(),iamAccount.getAuthSecret()) ; if (!matches){ throw new BusinessException(Status.FAIL_OPERATION, "舊密碼錯誤,請重新輸入"); } //判斷密碼是否包含相關的字符,數(shù)字,字母 if(!check(changePwdDTO.getConfirmPassword())){ throw new BusinessException(Status.FAIL_OPERATION, "密碼必須至少為8位字符,其中包含數(shù)字、字母及特殊字符"); }
2、強密碼驗證
包含數(shù)字、字母和特殊字符,長度要求8到30位
package security; /** * 密碼校驗:包含數(shù)字、字母和特殊字符,長度要求8到30位。 * @author lxzqz * */ public class CheckPassword { public static final String REGEX_PASSWORD_STRONG = "^(?![0-9]+$)(?![^0-9]+$)(?![a-zA-Z]+$)(?![^a-zA-Z]+$)(?![a-zA-Z0-9]+$)[a-zA-Z0-9\\S]{8,30}$"; /** * 密碼校驗,符合強密碼規(guī)則返回true,否則返回false * @param password * @return */ public static boolean check(String password) { boolean flag = password.matches(REGEX_PASSWORD_STRONG); return flag; } }
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Spring Session實現(xiàn)分布式session的簡單示例
本篇文章主要介紹了Spring Session實現(xiàn)分布式session的簡單示例,具有很好的參考價值。下面跟著小編一起來看下吧2017-05-05Java數(shù)據(jù)結構與算法實現(xiàn)遞歸與回溯
本文主要介紹了Java數(shù)據(jù)結構與算法實現(xiàn)遞歸與回溯,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03JAVA如何把數(shù)據(jù)庫的數(shù)據(jù)處理成樹形結構
本文介紹了JAVA如何把數(shù)據(jù)庫的數(shù)據(jù)處理成樹形結構,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09SpringBoot Logback日志記錄到數(shù)據(jù)庫的實現(xiàn)方法
這篇文章主要介紹了SpringBoot Logback日志記錄到數(shù)據(jù)庫的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11SpringBoot+RabbitMQ+Redis實現(xiàn)商品秒殺的示例代碼
本文主要介紹了SpringBoot+RabbitMQ+Redis實現(xiàn)商品秒殺,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11PipedWriter和PipedReader源碼分析_動力節(jié)點Java學院整理
這篇文章主要介紹了PipedWriter和PipedReader源碼分析_動力節(jié)點Java學院整理,需要的朋友可以參考下2017-05-05