以下是realm中自定义的代码:
```
//1.把AuthenticationToken转换为UsernamePasswordToken
UsernamePasswordTokenupToken=(UsernamePasswordToken)token;
//2.从UsernamePasswordToken中来获取username
Stringusername=upToken.getUsername();
System.out.println("doGetAuthenticationInfo---username:"+username);
//3.调用数据库的方法,从数据库中查询username对应的用户记录
System.out.println("2222");
TManagerUsermanagerUser=sysUserManagerService.queryUserByLoginName(username);
System.out.println("3333");
System.out.println("doGetAuthenticationInfo---managerUser:"+JSONObject.toJSON(managerUser));
//4.若用户不存在,则可以抛出UnknownAccountException异常
System.out.println("1111");
if(managerUser==null){
thrownewUnknownAccountException("用户不存在!");
}else{
//5.根据用户信息的情况,决定是否需要抛出其他的AuthenticationException异常.
if("locked".equals(managerUser.getUserStatus())){
thrownewLockedAccountException("用户被锁定");
}
//6.根据用户的情况,来构建AuthenticationInfo对象并返回.通常使用的实现类为:SimpleAuthenticationInfo
//以下信息是从数据库中获取的.
//1).principal:认证的实体信息.可以是username,也可以是数据表对应的用户的实体类对象.
Objectprincipal=username;
//2).credentials:密码.
Objectcredentials=managerUser.getUserPassword();
System.out.println("credentials:"+credentials);
//3).realmName:当前realm对象的name.调用父类的getName()方法即可
StringrealmName=getName();
//4).盐值.将用户名作为盐
ByteSourcecredentialsSalt=ByteSource.Util.bytes(username);
SimpleAuthenticationInfoinfo=null;//newSimpleAuthenticationInfo(principal,credentials,realmName);
info=newSimpleAuthenticationInfo(principal,credentials,credentialsSalt,realmName);
System.out.println("info:"+JSONObject.toJSON(info));
returninfo;
}
```
执行后后台只打印2222,也就是sysUserManagerService.queryUserByLoginName方法前的代码,方法后的代码根本不执行,后台还不报错,因为刚接触shiro,所以还望大神指点
分 -->
|