首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Spring Boot中传递用于POST的JSessionId和CSRF-Token

在Spring Boot中传递用于POST的JSessionId和CSRF-Token
EN

Stack Overflow用户
提问于 2018-12-18 05:56:25
回答 1查看 1.4K关注 0票数 1

我有Spring Boot 2.1.0.RELEASE应用程序。我正在尝试理解登录和CSRF配置,所以我首先发送一个GET请求:

代码语言:javascript
复制
 GET http://localhost:8080/devices
 Accept: application/json
 Authorization: Basic user test

对我收到的JSessionID再次执行同样的操作,也是有效的:

代码语言:javascript
复制
GET http://localhost:8080/devices
Accept: application/json
#Authorization: Basic user test
cookie: JSESSIONID=162A7A29081CC89EA444423D9508F286

到目前为止一切都很好。我收到了200个回复,我得到了一个CSRF令牌。后者:

代码语言:javascript
复制
HTTP/1.1 200 
Set-Cookie: XSRF-TOKEN=2adcabdd-d804-4f13-a2a6-b95621ce868c; Path=/
....

好了,现在我想直接尝试POST请求:

代码语言:javascript
复制
POST localhost:8080/devices/check
Content-Type: application/json
#Authorization: Basic user password
cookie: JSESSIONID=162A7A29081CC89EA444423D9508F286; XSRF-TOKEN=2adcabdd-d804-4f13-a2a6-b95621ce868c
#X-XSRF-TOKEN: 2adcabdd-d804-4f13-a2a6-b95621ce868c

但是独立地,如果我尝试通过Cookie或Header传递XSRF令牌,我将得到一个403禁止。

这是我的Spring Security配置:

代码语言:javascript
复制
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.csrf()
                .csrfTokenRepository(CookieCsrfTokenRepository
                        .withHttpOnlyFalse()).and()
                .authorizeRequests()
                .antMatchers("/", "/home").permitAll()
                .anyRequest().authenticated()
                .and()
                .httpBasic().and()
                .formLogin()
                .loginPage("/login")
                .permitAll()
                .and()
                .logout()
                .permitAll();
    }

}

我在这里做错了什么?

仅供参考:我正在使用IntelliJ超文本传输协议客户端。

EN

回答 1

Stack Overflow用户

发布于 2019-08-19 02:55:50

下面是我所做的:

从您的RequestContext检索您的cookie:

代码语言:javascript
复制
function getMyToken() {
    Cookies[] cookies = getRequestContext().getRequest().getCookies()
    for (cookie in cookies) {
        if (cookie.getName().equals("XSRF-TOKEN")) return cookie.getValue()
    }
}

然后在我的表格中:

代码语言:javascript
复制
<input name="_csrf" value="getMyToken()"/>

这对我很管用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53823547

复制
相关文章

相似问题

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