베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • 스프링
    • dfs
    • 알고리즘
    • java
    • 함수형인터페이스
    • 토비스프링
    • 백준
    • Spring
    • BFS
    • 이펙티브자바
    • 운영체제
    • 자바
    • 코드업
    • jpa
    • 스레드
    • 스프링시큐리티
    • 자바8
    • leetcode
    • 데이터베이스
    • C++

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    [Spring] 스프링의 세션 정책과 JWT 토큰 버그
    Spring

    [Spring] 스프링의 세션 정책과 JWT 토큰 버그

    2022. 10. 8. 23:29

    [문제]

    react-spring 팀 프로젝트에서는 JWT토큰을 기반으로 기능이 동작하고 있다. 인증 정보가 필요한 구간에서는 인터셉터를 이용하여 토큰 정보로 사용자 정보를 얻고 있는데, SecurityContextHolder에 Auth를 넣는 코드를 작성하고 이상한 버그가 발생하였다.

     

    2번에 한 번 꼴로 계속 구글 로그인 html파일이 응답으로 떨어졌다.

    구글 로그인 html 응답

     

     

    [분석]

    Security는 필터안에서 동작하기에 Filter의 로그를 출력해보기로 했다.

    다음과 같이 EnableWebSecurity 어노테이션에 debug = true를 설정해주면 로그를 확인할 수 있다. 

     

    구글 로그인 html 파일을 리턴 받았을 때도 다음과 같은 필터 체인이 실행되었다. (정상일 때와 같음)

    필터 실행 순서

     

    debug = true를 하면 필터 정보 이외에 다음과 같은 정보들도 제공해준다.

    디버깅 로그

     

    확인해보니 맨 윗줄에 session에 대한 정보를 확인했고, SecurityContext도 session에 저장된다는 것을 기억하고 Session에 대해서 검색해보았다.

     

    [해결]

    SessionPolicy.STATELESS로 설정을 해주었더니 해결되었다.

    SessionCreationPolicy의 속성값들

     

    기본 값이 IF_REQUIRED인데, 세션에 값을 안넣다가 이 세션에 값을 넣어주니 HttpSession을 만들었고 이것 때문에 구글 로그인과 충돌이 난 것 같다. 

     

     

      'Spring' 카테고리의 다른 글
      • [Spring] Controller에서 List 받는 방법
      • [Spring] 컨트롤러에서 요청을 받는 2가지 방법
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바