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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM