您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Spring Boot / Spring Security正在忽略来自JavaScript的/ login调用

Spring Boot / Spring Security正在忽略来自JavaScript的/ login调用

这是对我有用的答案/解决方案。根据本文(http://patrickgrimard.com/2014/01/03/spring-security- csrf-protection-in-a-backbone-single-page- app/),添加CSRFTokenGeneratorFilter extends OncePerRequestFilter 并连接至我的安全性配置,允许使用我的javascript提供的参数。

public final class CSRFTokenGeneratorFilter extends OncePerRequestFilter {
    @Override
    protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
        CsrfToken token = (CsrfToken) request.getAttribute("_csrf");

        response.setHeader("X-CSRF-HEADER", token.getHeaderName());
        response.setHeader("X-CSRF-PARAM", token.getParameterName());
        response.setHeader("X-CSRF-TOKEN", token.getToken());
        filterChain.doFilter(request, response);
    }
}

接线如下:

@Configuration
@EnableWebMvcSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Autowired
    private CustomUserDetailsService customUserDetailsService;

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
                .addFilterAfter(new CSRFTokenGeneratorFilter(), CsrfFilter.class)
                .authorizeRequests()
                .antMatchers("/").permitAll()
                .antMatchers("/login").permitAll()
..}
}

我不确定为什么需要过滤器,但是我想spring-boot / security不会使用它作为认值。

javascript 2022/1/1 18:16:54 有513人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶