更新时间:2020-08-14 来源:黑马程序员 浏览量:
package com.itheima.shiro.service.impl; import com.itheima.shiro.service.SecurityService; /** * @Description:权限服务层 */ public class SecurityServiceImpl implements SecurityService { @Override public String findPasswordByLoginName(String loginName) { return "123"; } }
【1】新建项目
shiro-day01-05-ciphertext-realm
【2】创建密文密码
使用ClientTest的testDigestsUtil创建密码为“123”的password密文和salt密文。
password:56265d624e484ca62c6dfbc523e6d6fc7932d0d5 salt:845a66ac80174c0e486db9354cf84f9a
【3】修改SecurityService
SecurityService修改成返回salt和password的map
package com.itheima.shiro.service; import java.util.Map; /** * @Description:权限服务接口 */ public interface SecurityService { /** * @Description 查找密码按用户登录名 * @param loginName 登录名称 * @return */ Map<String,String> findPasswordByLoginName(String loginName); }
package com.itheima.shiro.service.impl; import com.itheima.shiro.service.SecurityService; import java.util.HashMap; import java.util.Map; /** * @Description:权限服务层 */ public class SecurityServiceImpl implements SecurityService { @Override public Map<String,String> findPasswordByLoginName(String loginName) { //模拟数据库中存储的密文信息 return DigestsUtil.entryptPassword("123"); } }
【4】指定密码匹配方式
为DefinitionRealm类添加构造方法如下:
/** * @Description 构造函数 */ public DefinitionRealm() { //指定密码匹配方式为sha1 HashedCredentialsMatcher matcher = new HashedCredentialsMatcher(DigestsUtil.SHA1); //指定密码迭代次数 matcher.setHashIterations(DigestsUtil.ITERATIONS); //使用父亲方法使匹配方式生效 setCredentialsMatcher(matcher); }
修改DefinitionRealm类的认证doGetAuthenticationInfo方法如下
/** * @Description 认证接口 * @param token 传递登录token * @return */ @Override protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException { //从AuthenticationToken中获得登录名称 String loginName = (String) token.getPrincipal(); SecurityService securityService = new SecurityServiceImpl(); Map<String, String> map = securityService.findPasswordByLoginName(loginName); if (map.isEmpty()){ throw new UnknownAccountException("账户不存在"); } String salt = map.get("salt"); String password = map.get("password"); //传递账号和密码:参数1:缓存对象,参数2:明文密码,参数三:字节salt,参数4:当前DefinitionRealm名称 return new SimpleAuthenticationInfo(loginName,password, ByteSource.Util.bytes(salt),getName()); }
【5】测试
猜你喜欢:
【AI设计】北京143期毕业仅36天,全员拿下高薪offer!黑马AI设计连续6期100%高薪就业
2025-09-19【跨境电商运营】深圳跨境电商运营毕业22个工作日,就业率91%+,最高薪资达13500元
2025-09-19【AI运维】郑州运维1期就业班,毕业14个工作日,班级93%同学已拿到Offer, 一线均薪资 1W+
2025-09-19【AI鸿蒙开发】上海校区AI鸿蒙开发4期5期,距离毕业21天,就业率91%,平均薪资14046元
2025-09-19【AI大模型开发-Python】毕业33个工作日,就业率已达到94.55%,班均薪资20763元
2025-09-19【AI智能应用开发-Java】毕业5个工作日就业率98.18%,最高薪资 17.5k*13薪,全班平均薪资9244元
2025-09-19