SpringBoot 集成 Shiro:使用Shiro的加密功能

Posted Stark_Tan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringBoot 集成 Shiro:使用Shiro的加密功能相关的知识,希望对你有一定的参考价值。

  因为在实际应用中用户密码不会使用明文保存,最广泛的是使用md5 sha等不可逆的加密算法将密码加密后存入数据库,所以在认证的时候也要将登录请求中的密码做同样的加密才能与数据库中数据做比对。

  创建用户

技术分享图片
@Getter
@Setter
public class User implements Serializable {
    private String id;
    private String username;
    private String password;
    private String salt;
    public User(String username, String password) {
        this.id = UUID.randomUUID().toString().replace("-", "");
        this.username = username;
        this.salt = getId().substring(0, 6);
        this.password = new Sha512Hash(password, getSalt()).toString();
    }
}
User.java

  创建数据源

技术分享图片
public class UserService {
    private static final Map<String, User> userMap = new HashMap<>();
    static {
        userMap.put("admin1", new User("admin1", "123456"));
        userMap.put("admin2", new User("admin2", "123456"));
    }
    public static User getUserByName(String name) {
        return userMap.get(name);
    }
}
UserService.java

  修改MyRealm

技术分享图片
protected AuthenticationInfo doGetAuthenticationInfo(
        AuthenticationToken authcToken) throws AuthenticationException {
    UsernamePasswordToken token = (UsernamePasswordToken) authcToken;
    String name = token.getUsername();
    String password = String.valueOf(token.getPassword());
    User user = UserService.getUserByName(name);
    if (null == user) {
        return null;
    } else {
        String credentials = new Sha512Hash(password, user.getSalt()).toString();
        token.setPassword(credentials.toCharArray());
        return new SimpleAuthenticationInfo(user, user.getPassword(), getName());
    }
}
MyRealm.java

 源码地址:https://github.com/StarkTan/SpringBootShiro

以上是关于SpringBoot 集成 Shiro:使用Shiro的加密功能的主要内容,如果未能解决你的问题,请参考以下文章

Shiro集成web环境[Springboot]-基础使用

SpringBoot 集成 Shiro:使用Shiro的角色管理

SpringBoot 集成 Shiro:使用Shiro的权限管理

SpringBoot 集成 Shiro:使用Shiro的加密功能

Shiro Web集成及拦截器机制

SpringBoot--集成Shiro