通常,当页面一直待到会话到期并且我尝试提交POST操作时,Spring Security生成的CSRF令牌将不匹配服务器的预期值.在这种情况下,错误是预期的结果.
但是,我总是得到默认的Tomcat 403错误,这是非常难看的.它是由安全筛选器抛出的403错误引起的.
但是,我想拦截特定的CSRF错误以执行自定义操作.即,以下操作无效,因为错误比MVC管道早得多
@ExceptionHandler(CsrfException.class)
public String exception(CsrfException ex)
{
log.error(ex.getMessage(),ex);
return "redirect:/index.jsp";
}
最佳答案
要检查CSRF,Spring Security使用CsrfFilter.如果令牌丢失或无效,则使用AccessDeniedHandler
if (missingToken) {
accessDeniedHandler.handle(request,response,new MissingCsrftokenException(actualToken));
}
else {
accessDeniedHandler.handle(request,new InvalidCsrftokenException(csrftoken,actualToken));
}
@Override
public void configure(HttpSecurity http) throws Exception {
HttpSecurity http = http.exceptionHandling().accessDeniedHandler(myAccessDeniedHandler);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。