Shiro认证及授权说明备忘

来源:互联网 发布:php dynamodb 编辑:程序博客网 时间:2024/05/29 04:43

1.首先创建自己的MyShiroRealm 继承自JdbcRealm 来其目的是可在必要情况下实现自定义的认证授权策略。

public class MyShiroRealm extends JdbcRealm {


   @Resource
   private XAccountService accountService;
   
  /**
   * 认证回调函数
   */
  @Override  
  protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken){  
      UsernamePasswordToken token = (UsernamePasswordToken) authenticationToken;    
      String username = token.getUsername();
      Account account = accountService.selectByName(username);
      if (account == null) {
          throw new AccountNoneException();
      }

      SimpleAuthenticationInfo authenticationInfo = new SimpleAuthenticationInfo(account.getUsername(),
      account.getPassword().toCharArray(), getName());

      if (StringUtils.isNotBlank(account.getSalt())) 
          authenticationInfo.setCredentialsSalt(ByteSource.Util.bytes(account.getSalt()));

      return authenticationInfo;
  }  
}
0 0
原创粉丝点击