shiro 是如何判断 用户密码正确与否的
作者:互联网
// 配置 shiro
/** * 告诉shiro我的加密算法 * @return */ @Bean public HashedCredentialsMatcher hashedCredentialsMatcher() { HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher(); hashedCredentialsMatcher.setHashAlgorithmName("MD5");//采用MD5 进行加密 hashedCredentialsMatcher.setHashIterations(1);//加密次数 return hashedCredentialsMatcher; } /** * 配置realm,用于认证和授权 * @param hashedCredentialsMatcher * @return */ @Bean public AuthorizingRealm shiroRealm(HashedCredentialsMatcher hashedCredentialsMatcher) { MyShiroRealm shiroRealm = new MyShiroRealm(); //校验密码用到的算法 shiroRealm.setCredentialsMatcher(hashedCredentialsMatcher); return shiroRealm; }
...
... // 触发登录逻辑 String userName = user.getUsername(); Subject currentUser = SecurityUtils.getSubject(); //是否已经登录 if (!currentUser.isAuthenticated()) { // 告诉 shiro 我输入的密码 UsernamePasswordToken token = new UsernamePasswordToken(userName, user.getPassword()); try { token.setRememberMe(true); //触发 shiro 检查密码逻辑 currentUser.login(token);
...
/** * 认证登录 */ @Override protected AuthenticationInfo doGetAuthenticationInfo( AuthenticationToken token) throws AuthenticationException { // 输入的用户名密码 String username = (String) token.getPrincipal(); String password = new String((char[]) token.getCredentials()); // 通过username从数据库中查找 User对象,如果找到,没找到. // 实际项目中,这里可以根据实际情况做缓存,如果不做,Shiro自己也是有时间间隔机制,2分钟内不会重复执行该方法 这里相当于拿到了 数据库中的用户名及密码 TsysUser userInfo = tsysUserDao.queryUserName(username); // 告诉 shiro 我的真正密码 和之前配置的加密算法 比对 SimpleAuthenticationInfo authenticationInfo = new SimpleAuthenticationInfo( username, // 用户对象 userInfo.getPassword(), // 真正加密后的密码 getName() // realm name ); return authenticationInfo; }
标签:return,String,与否,密码,token,hashedCredentialsMatcher,shiro 来源: https://blog.csdn.net/csdnkalunren/article/details/110227139