SpringBoot Shiro配置自定義密碼加密器代碼實(shí)例
shiro主要有三大功能模塊:
1. Subject:主體,一般指用戶。
2. SecurityManager:安全管理器,管理所有Subject,可以配合內(nèi)部安全組件。(類似于SpringMVC中的DispatcherServlet)
3. Realms:用于進(jìn)行權(quán)限信息的驗(yàn)證,一般需要自己實(shí)現(xiàn)。
細(xì)分功能
- 1. Authentication:身份認(rèn)證/登錄(賬號(hào)密碼驗(yàn)證)。
- 2. Authorization:授權(quán),即角色或者權(quán)限驗(yàn)證。
- 3. Session Manager:會(huì)話管理,用戶登錄后的session相關(guān)管理。
- 4. Cryptography:加密,密碼加密等。
- 5. Web Support:Web支持,集成Web環(huán)境。
- 6. Caching:緩存,用戶信息、角色、權(quán)限等緩存到如redis等緩存中。
- 7. Concurrency:多線程并發(fā)驗(yàn)證,在一個(gè)線程中開啟另一個(gè)線程,可以把權(quán)限自動(dòng)傳播過去。
- 8. Testing:測(cè)試支持;
- 9. Run As:允許一個(gè)用戶假裝為另一個(gè)用戶(如果他們?cè)试S)的身份進(jìn)行訪問。
- 10. Remember Me:記住我,登錄后,下次再來的話不用登錄了。
自定義認(rèn)證加密方式
/**
* 自定義認(rèn)證加密方式
*/
public static class CustomCredentialsMatcher extends SimpleCredentialsMatcher {
@Override
public boolean doCredentialsMatch(AuthenticationToken authcToken, AuthenticationInfo info) {
UsernamePasswordToken token = (UsernamePasswordToken) authcToken;
//加密類型,密碼,鹽值,迭代次數(shù)
Object tokenCredentials = new SimpleHash("md5", password, username, 2).toHex();
//數(shù)據(jù)庫存儲(chǔ)密碼
Object accountCredentials = getCredentials(info);
//將密碼加密與系統(tǒng)加密后的密碼校驗(yàn),內(nèi)容一致就返回true,不一致就返回false
return equals(tokenCredentials, accountCredentials);
}
}
第一種方式:配置Bean
/**
* Shiro自帶密碼管理器
*
* @return HashedCredentialsMatcher
*/
@Bean
public HashedCredentialsMatcher hashedCredentialsMatcher() {
//Shiro自帶加密
HashedCredentialsMatcher credentialsMatcher = new HashedCredentialsMatcher();
//散列算法使用md5
credentialsMatcher.setHashAlgorithmName("md5");
//散列次數(shù),2表示md5加密兩次
credentialsMatcher.setHashIterations(2);
credentialsMatcher.setStoredCredentialsHexEncoded(true);
return credentialsMatcher;
}
/**
* 將自己的身份驗(yàn)證器驗(yàn)證方式加入容器
*
* @return CustomRealm
*/
@Bean
public CustomRealm shiroRealm() {
CustomRealm shiroRealm = new CustomRealm();
//shiroRealm.setCacheManager(cacheManager());
//加入密碼管理
//shiroRealm.setCredentialsMatcher(hashedCredentialsMatcher());//Shiro自帶密碼管理器
shiroRealm.setCredentialsMatcher(new CustomCredentialsMatcher());//自定義密碼管理器
return shiroRealm;
}
第二種方式:實(shí)現(xiàn)AuthorizingRealm類setCredentialsMatcher方法
public class CustomRealm extends AuthorizingRealm {
...
...
...
/**
* 設(shè)置自定義認(rèn)證加密方式
*
* @param credentialsMatcher 默認(rèn)加密方式
*/
@Override
public void setCredentialsMatcher(CredentialsMatcher credentialsMatcher) {
//自定義認(rèn)證加密方式
CustomCredentialsMatcher customCredentialsMatcher = new CustomCredentialsMatcher();
// 設(shè)置自定義認(rèn)證加密方式
super.setCredentialsMatcher(customCredentialsMatcher);
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringBoot配置文件中數(shù)據(jù)庫密碼加密兩種方案(推薦)
- Springboot實(shí)現(xiàn)密碼的加密解密
- SpringBoot+Shiro學(xué)習(xí)之密碼加密和登錄失敗次數(shù)限制示例
- SpringBoot項(xiàng)目application.yml文件數(shù)據(jù)庫配置密碼加密的方法
- Springboot項(xiàng)目對(duì)數(shù)據(jù)庫用戶名密碼實(shí)現(xiàn)加密過程解析
- Springboot Druid 自定義加密數(shù)據(jù)庫密碼的幾種方案
- SpringBoot中使用com.alibaba.druid.filter.config.ConfigTools對(duì)數(shù)據(jù)庫密碼加密的方法
- springboot對(duì)數(shù)據(jù)庫密碼加密的實(shí)現(xiàn)
- SpringBoot配置數(shù)據(jù)庫密碼加密的實(shí)現(xiàn)
- springboot數(shù)據(jù)庫密碼加密的配置方法
相關(guān)文章
詳解Spring Cloud負(fù)載均衡重要組件Ribbon中重要類的用法
本篇文章主要介紹了詳解Spring Cloud負(fù)載均衡重要組件Ribbon中重要類的用法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03
集合框架及背后的數(shù)據(jù)結(jié)構(gòu)
本文主要介紹了Java的集合框架Java?Collection?Framework,接口interface以及背后的數(shù)據(jù)結(jié)構(gòu),感興趣的同學(xué)可以閱讀參考2023-03-03
解決mybatis使用foreach批量insert異常的問題
這篇文章主要介紹了解決mybatis使用foreach批量insert異常的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01
關(guān)于Feign調(diào)用服務(wù)Headers傳參問題
這篇文章主要介紹了關(guān)于Feign調(diào)用服務(wù)Headers傳參問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
Java使用Junit4.jar進(jìn)行單元測(cè)試的方法
今天通過本文給大家介紹Java使用Junit4.jar進(jìn)行單元測(cè)試的方法,本文通過圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-11-11
Java修飾符 abstract,static,final 的區(qū)別詳解
以下是對(duì)Java修飾符abstract,static,final的區(qū)別進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下2013-09-09
MyBatis攔截器實(shí)現(xiàn)分頁功能實(shí)例
本篇文章主要介紹了MyBatis攔截器實(shí)現(xiàn)分頁功能實(shí)例,這里整理了詳細(xì)的代碼,有需要的小伙伴可以參考下。2017-04-04
Java?ObjectMapper的使用和使用過程中遇到的問題
在Java開發(fā)中,ObjectMapper是Jackson庫的核心類,用于將Java對(duì)象序列化為JSON字符串,或者將JSON字符串反序列化為Java對(duì)象,這篇文章主要介紹了Java?ObjectMapper的使用和使用過程中遇到的問題,需要的朋友可以參考下2024-07-07

