做者 : Stanley 罗昊前端
【转载请注明出处和署名,谢谢!】数据库
讲解:app
首先,若是你登录失败的时候,它会把你的异常信息丢到一个叫shirologinFailure这个值里面,这个值对应上咱们的请求做用域中,它的key值就是shirologinFailure;jsp
咱们从中能够获取到异常的名称(异常错误信息)咱们用string来接收异常信息exceptionClassName,而后咱们就能够开始判断,若是exceptionClassName !=null的时候,那就代表登录失败了,登录失败以后,咱们就直接return “forward/login.jsp”;就直接给他跳转到登录页面,让用户继续登录;spa
那咱们登录成功呢?注意看下方注解:code
该方法不处理登录成功的状况,会自动帮咱们跳转到上一个操做路径,因此登录失败了就会进入到这个方法中返回一个登录页面,若是成功,压根就不会进入这个方法,而是直接跳转到咱们以前所保留的那个登录路径;xml
当咱们尝试登录的时候,咱们就会发现没法登录,返回的内容倒是用户名不存在;对象
由于,当咱们登录的时候,shiro会首先经过咱们自定义的Realm进行操做【也就是咱们编写的UserRealm类】,咱们在下方能够看到//认证操做,该方法返回的结果是null,null的意思就是找不到用户信息,好比咱们刚才在文本框输入用户名:zhangsan,这个时候咱们查询不出来,就从该认证器中返回一个null告诉用户,找不到;blog
因此,咱们接下来须要把认证器补充完整;token
咱们能够看到该方法有一个参数token,没错,咱们就是要经过这个token来获取咱们前端用户传过来的用户名(UserName),而后去咱们数据库中进行查询对比;对比下你是否拥有这个用户,若是有的话,我就直接把它返回就能够了;
接下来,咱们就须要从token中获取登录的用户名(用户填写的文本框中的值),查询数据库返回用户信息;那咱们要怎样获取用户Name呢》其实很是简单:
String username = (String) token.getPrincipal();//用来获取用户名
接下来,咱们拿到这个用户名后,咱们就能够进行dao【Mybiats就是Mapper来完成操做】的JDBC操做了,由于咱们用的是Spring环境,咱们就能够经过依赖注入的方式来进行操做,咱们直接将登录的接口注入进来,将获取到的用户名直接丢进去便可;具体步骤:
1.咱们在Dao【Mapper层】中找到User这个接口层而且编写接口:User getUserByUsername(String username);//获取用户对象,经过用户名查询获取;
2.在Service层重写Mapper结构并编写实现类impl,直接调Mapper层中的登录接口,直接retrun方法;
@Autowired private UserMapper userMapper; public User getUserByUsername(String username){ return userMapper.getUserByUsername(username); }
2.Sql语句:Select * From user(表名) where username = ?;查询返回咱们的User对象【Mybiats在.xml文件中编写Sql】;
3.使用依赖注入,将Service注入到受权器中;
String username = (String) token.getPrincipal();//用来获取用户名 User user = userService.getUserByUsername(username);
4.判断
if (ObjectUtils.isEmpty(user){ //若是用户名不存在,直接返回null便可 return null; }else{ //若是该用户存在 /** * 1.用户对象 * 2.用户对应的密码,将数据库密码返回,Shiro会自动判断 * 3.上方定义的Realm名字(当前自定义Realm的名称) */ return new SimpleAuthenticationInfo(user,user.getpassword,getName); }