在 Spring Security 中自定义 CSRF 错误页面

Posted

技术标签:

【中文标题】在 Spring Security 中自定义 CSRF 错误页面【英文标题】:Customizing CSRF error page in Spring Security 【发布时间】:2016-01-21 10:24:56 【问题描述】:

通常,当一个页面离开到会话到期并且我尝试提交一个 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 令牌错误并自定义服务器响应?

【问题讨论】:

500 通常表示未捕获的异常。你能找到堆栈跟踪吗? 对不起,我的意思是 403。我将处理当前的答案 【参考方案1】:

为了检查 CSRF Spring Security 使用CsrfFilter。如果令牌丢失或无效,它会使用 AccessDeniedHandler

if (missingToken) 
                accessDeniedHandler.handle(request, response,
                        new MissingCsrfTokenException(actualToken));
            
            else 
                accessDeniedHandler.handle(request, response,
                        new InvalidCsrfTokenException(csrfToken, actualToken));
            

所以处理这个错误的一种方法可能是这个处理程序自己的实现

@Override
  public void configure(HttpSecurity http) throws Exception 
    HttpSecurity http = http.exceptionHandling().accessDeniedHandler(myAccessDeniedHandler);

【讨论】:

我将在 XML 中执行此操作(需要找到设置它的位置),无论如何这会导致正确的路径

以上是关于在 Spring Security 中自定义 CSRF 错误页面的主要内容,如果未能解决你的问题,请参考以下文章

使用 AuthenticationFailureHandler 在 Spring Security 中自定义身份验证失败响应

在 Spring Security 中自定义 CSRF 错误页面

如何在 Spring Security 中自定义权限表达式

如何在 Spring Security 中自定义权限表达式

如何在 Spring Security 中自定义权限表达式

Spring Security:无法在前端进行身份验证