首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >启用/禁用客户端类型的CSRF保护(浏览器/非浏览器)?

启用/禁用客户端类型的CSRF保护(浏览器/非浏览器)?
EN

Stack Overflow用户
提问于 2022-03-18 15:18:22
回答 3查看 1.4K关注 0票数 1

我有一个。由于安全策略,我需要为浏览器访问的端点启用CSRF保护。然而,这个API也将被非浏览器访问.是否有一种方法可以创建两组端点,一个只有启用CSRF的浏览器才能访问,另一个只有禁用CSRF的非浏览器才能访问?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2022-03-18 16:42:51

当您使用DSL配置您的CSRF保护时,像这个http.csrf()...一样,您可以通过传递一个RequestMatcher来判断哪些请求要应用CSRF保护,如下所示:

代码语言:javascript
复制
http.csrf(csrf -> csrf.requireCsrfProtectionMatcher(new MyBrowserRequestMatcher()));

RequestMatcher的实现可以验证HttpServletRequest是否包含标头X-Requested-With: XMLHttpRequest或检查User-Agent

请记住,标题可以更改,您无法保证请求实际上来自浏览器或非浏览器应用程序。

票数 2
EN

Stack Overflow用户

发布于 2022-03-18 15:51:24

我认为您可以为浏览器请求和API请求建立单独的URL库。

例如,可以让非浏览器在/api/...下查询所有端点,在SpringBootSecurityConfiguration类和configure(HttpSecurity http)方法中,如果模式匹配,您可以有条件地禁用CSRF和http.csrf().disable(); (很好的教程可以找到这里 )。

编辑:这是另一个可能有用的回答

票数 0
EN

Stack Overflow用户

发布于 2022-09-05 11:12:04

正如@ferrouskid所说,我创建了两个URL,一个用于浏览器,另一个用于非浏览器:

在spring安全配置中:

代码语言:javascript
复制
@Override
protected void configure(HttpSecurity http) throws Exception {
    super.configure(http);
    http.csrf().ignoringAntMatchers("/withoutCsrf/**")
            .csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse())
            .and()
            .cors().disable();
//complete your configuration }

在主计长:

代码语言:javascript
复制
@Controller
@RequestMapping({"books","withoutCsrf/books"})
public class BookController {}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71529268

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档