springsecurity6.x+gradle+kotlin+thymelef学习笔记 - 10.异常处理(上)

当验证码输入正常,但用户名或密码输入错误时,可以看到控制台里有错误信息,但页面上除了链接后面加了个 ?error外,什么提示都没有
在这里插入图片描述
这篇来处理一下springsecurity认证授权的异常

查源码

SecurityConfig.kt里配置 HttpSecurity 的地方,有一个 formLogin的配置
在这里插入图片描述
点进去可以看到 formLogin里面还有这么多属性

@SecurityMarker
class FormLoginDsl {
    var loginPage: String? = null
    var authenticationSuccessHandler: AuthenticationSuccessHandler? = null
    var authenticationFailureHandler: AuthenticationFailureHandler? = null
    var failureUrl: String? = null
    var loginProcessingUrl: String? = null
    var permitAll: Boolean? = null
    var authenticationDetailsSource: AuthenticationDetailsSource<HttpServletRequest, *>? = null
    var usernameParameter: String? = null
    var passwordParameter: String? = null

    private var defaultSuccessUrlOption: Pair<String, Boolean>? = null

根据属性名可知

  • authenticationSuccessHandler 是认证成功的操作逻辑
  • authenticationFailureHandler 是认证失败的操作逻辑

AuthenticationFailureHandler是一个接口,并有如下这些已经实现的类
在这里插入图片描述
打开 AbstractAuthenticationProcessingFilter 可以看到springsecurity默认给的failureHandler其实是 SimpleUrlAuthenticationFailureHandler
在这里插入图片描述
打开 SimpleUrlAuthenticationFailureHandler可以看到出异常的话,会跳转或重定向到一个 defaultFailureUrl的地址上
在这里插入图片描述
往上翻,能看到这个defaultFailureUrl参数是通过构造方法传进来的
在这里插入图片描述
SimpleUrlAuthenticationFailureHandler 的构造方法又在 AbstractAuthenticationFilterConfigurer里被调用并传了一个 authenticationFailureUrl
在这里插入图片描述
failureUrl()在当前类里被调用,并将 loginUrl的值拼接上了 ?error 传入了
在这里插入图片描述
所以SimpleUrlAuthenticationFailureHandler里的 defaultFailureUrl就来自于在SecurityConfig.kt里配置的loginUrl了。
所以这里也没必要再重新在SecurityConfig.kt里配置一遍
在这里插入图片描述
回到SimpleUrlAuthenticationFailureHandler里,当出现异常时,会调用一个saveException()方法用来处理异常信息的响应

如果是跳转,就会将异常放进 request 里返回,如果是重定向,就会放进 session里返回
在这里插入图片描述
SimpleUrlAuthenticationFailureHandler 里默认的跳转方式是重定向 private boolean forwardToDestination = false;

所以异常信息就被放在了 session 里,键是 WebAttributes.AUTHENTICATION_EXCEPTION ,也就是 SPRING_SECURITY_LAST_EXCEPTION
在这里插入图片描述
看到这就知道怎么在页面上取异常信息了

登录页

<form th:action="@{/loginpost}" method="POST">
    <fieldset>
        <legend>登录</legend>
        <!-- 从session中获取异常信息 -->
        <p th:text="${#ctx.session.SPRING_SECURITY_LAST_EXCEPTION?.message}" style="color:red;"></p>
        <ul>
            <li th:each="msg : ${#ctx.session.loginpost_errors}" th:text="${msg}"></li>
        </ul>
        <label for="username">用户名</label><br>
        <input type="text" name="username" id="username" placeholder="用户名"> <br>
        <label for="password">密码</label><br>
        <input type="password" name="password" id="password" placeholder="密码"> <br>
        <label for="code">验证码</label><br>
        <input type="text" name="code" id="code" placeholder="验证码"> <img th:src="@{/captcha}" alt="Captcha" id="captchaImg" onclick="updateCaptcha()"><br>
        <button type="submit">登录</button>
    </fieldset>
</form>

看一下效果
在这里插入图片描述
异常信息是英文的,springsecurity框架里给提供了国际化
在这里插入图片描述
所以只需要修改一下浏览器的请求接收语言为中文就行了
在这里插入图片描述
以firefox为例,设置位置在
在这里插入图片描述

总结

  • springsecurity默认提供了SimpleUrlAuthenticationFailureHandler的异常处理方式,我们只需稍加利用它定的规则就行了
  • spring框架对国际化支持的很好,不过要浏览器进行配合
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值