本章我们来讲解,如果使用 Shiro 集成 Spring 后,使用加密功能。本章基础代码为上一章 : Shiro 集成 Spring 中的代码。
我们这里演示使用 md5
散列算法进行加密, 并用 TestSalt
作为盐。
首先导入上一章的代码,然后修改 spring-shiro.xml
,添加内容:
1 | <bean id="credentialsMatcher" class="org.apache.shiro.authc.credential.HashedCredentialsMatcher"> |
然后将此凭证匹配器 credentialsMatcher
注入到 Realm
中 :
1 | <bean id="myRealm" class="im.zhaojun.realm.MyRealm"> |
并在 Realm 中的 doGetAuthenticationInfo
方法里添加盐的配置 :
1 |
|
既然为 Relam 配置了凭证匹配器,那么就应该把我们存储的密码也进行加密,原始我们的密码为 123456
,这里我们使用 md5
散列算法进行加密,并使用 TestSalt
作为盐 :
1 | public class GenerateHash { |
然后我们将 Realm
中获取的密码改为加密后的值 e5f728a966d050296c428290c9160dda
:
1 | private User selectUserByUserName(String username) { |
同上一章,运行项目,进行登陆测试,即可检验结果。
本章代码地址 : https://github.com/zhaojun1998/Premission-Study/tree/master/Permission-Shiro-06/