栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

这是对我有用的答案/解决方案。根据本文(http://patrickgrimard.com/2014/01/03/spring-security-
csrf-protection-in-a-backbone-single-page-
app/
),添加

CSRFTokenGeneratorFilter extendsOncePerRequestFilter
并连接至我的安全性配置,允许使用我的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@EnableWebMvcSecuritypublic 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不会使用它作为默认值。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/387220.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号