【发布时间】:2018-08-05 17:16:42
【问题描述】:
我有一个 REST 服务,使用 Java、Spring-boot 构建,并使用带有基本访问身份验证的 Spring Security。没有视图,没有 JSP 等,没有“登录”,只有可以从单独托管的 React 应用程序调用的无状态服务。
我已经阅读了各种有关 CSRF 保护的文档,但无法决定我应该使用 spring-security CSRF 配置,还是仅仅禁用它?如果我禁用 csrf 保护,我可以使用 curl 使用我的基本身份验证调用服务,如下所示:
curl -H "authorization:Basic c35sdfsdfjpzYzB0dDFzaHA=" -H "content-type:application/json" -d '{"username":"user","password":"password","roles":"USER"}' localhost:8081/api/v1/user
如果我启用 csrf 保护并提供 x-csrf-token 标头,则 spring CsrfFilter 会尝试将其与来自(我认为)HttpServletRequest 中的会话 cookie 的值进行交叉检查。但是,由于它是无状态的 REST 服务,因此我没有会话,也没有“登录”。
我有一个如下所示的配置类:
@EnableWebSecurity
@Configuration
public class ServiceSecurityConfigurationAdapter extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.anyRequest().fullyAuthenticated()
.and().httpBasic();
if (!serviceProperties.isCsrfEnabled()) {
http.csrf().disable();
}
}
我想得越多,似乎我就越需要禁用 CSRF 保护。是否有另一种方法来配置 Spring Security 以使其正常工作?
谢谢
【问题讨论】:
标签: java rest spring-boot spring-security csrf