SpringSecurit鹽值加密的密碼驗證以及強密碼驗證過程
更新時間:2024年10月10日 10:37:58 作者:思祺班
在密碼加密過程中,鹽值的使用可以增強密碼的安全性,如果忘記存儲鹽值,將無法驗證密碼,強密碼應(yīng)包含數(shù)字、字母和特殊字符,長度應(yīng)在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, "舊密碼錯誤,請重新輸入");
}
//判斷密碼是否包含相關(guān)的字符,數(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;
}
}總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot+MyBatis+Redis實現(xiàn)分布式緩存
本文主要介紹了SpringBoot+MyBatis+Redis實現(xiàn)分布式緩存,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2024-01-01
.NET Core使用SignalR實現(xiàn)實時通訊的示例代碼
SignalR是一個ASP.NETCore庫,用于在客戶端和服務(wù)器之間實現(xiàn)實時通訊,本文主要介紹了.NETCore中使用SignalR實現(xiàn)實時通訊,感興趣的可以了解一下2024-11-11
利用Mybatis向PostgreSQL中插入并查詢JSON字段
這篇文章主要介紹了利用Mybatis向PostgreSQL中插入并查詢JSON字段,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07

