SpringMVC+Shiro 实现异步登录

本文介绍了如何在SpringMVC中结合Shiro实现异步登录。重点在于ShiroDatabaseRealm的异常捕获,以及自定义LoginFormAuthenticationFilter以处理登录成功和失败的拦截。通过在ShiroDatabaseRealm中捕获AuthenticationException,可以精确获取登录失败的原因。在登录失败时,根据异常类型定制错误信息,并确保仅拦截异步请求。登录成功后,针对异步请求发送成功的响应。
摘要由CSDN通过智能技术生成

在 ShiroDatabaseRealm 中对登录结果进行异常捕获

shiro的登录判断是在 ShiroDatabaseRealm 中通过 doGetAuthenticationInfo() 实现的

ShiroDatabaseRealm 是用户自定义的 AuthorizingRealm 子类,用于处理具体的登录逻辑

在 ShiroDatabaseRealm 中做异常捕获的原因是方便后续拦截器直接获取登录失败的原因

public class ShiroDatabaseRealm extends AuthorizingRealm {
private UniversityMemberServiceImpl universityMemberService;

public void setUniversityMemberService(UniversityMemberServiceImpl universityMemberService) {
    this.universityMemberService = universityMemberService;
}

@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authcToken) throws

AuthenticationException {
UsernamePasswordCheckCodeToken token = (UsernamePasswordCheckCodeToken) authcToken;
token.setRememberMe(false);

    UniversityMemberDTO member = universityMemberService.getUniversityMember(token.getUsername());

    // 未获取到用户信
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值