조작된 토큰으로 SignatureException 발생 예외 처리

2024. 2. 2. 12:46· 프로젝트/씈크럼 프로젝트

현재 AccessToken, RefreshToken을 전부 쿠키로 담아서 전송하도록 만들었다.

심심해서 쿠키에 있는 AccessToken을 조금 바꿔서 swagger로 전송을 보냈더니 바로

SignatureException을 뱉어내기 시작했다.

 

문제는 내 코드에 해당 에러를 처리해주는 부분이 없었다는 거.

그래서 응답으로 이렇게 500에러가 터져버린다.

그래서 토큰에서 값을 파싱할 때 해당 예외처리를 진행해주었다.

public Long getUserId(String token){                                         
    try {                                                                    
        return Jwts.parser().setSigningKey(SECRET_KEY).parseClaimsJws(token) 
                .getBody().get("userId", Long.class);                        
    } catch (ExpiredJwtException e) {                                        
        // 만료된 JWT에서도 userId는 가져옴.                                           
        return e.getClaims().get("userId", Long.class);                      
    } catch (SignatureException e){                                          
        throw e;                                                             
    }                                                                        
}

마지막에 SignatureException을 던져주고

해당 메서드를 부르는 밖에서 catch로 잡아서 응답을 따로 생성해주었다.

catch (SignatureException e){                                                   
   log.error("잘못된 JWT 서명입니다.", e);                                              
   response.setStatus(HttpServletResponse.SC_UNAUTHORIZED); // 401 상태 코드 설정     
   response.setContentType("application/json");                                 
   response.setCharacterEncoding("UTF-8");                                      
   response.getWriter().write("{\n" +                                           
           "  \"status\": \"error\",\n" +                                       
           "  \"data\": null,\n" +                                              
           "  \"message\": \"잘못된 서명의 토큰입니다.\"\n" +                              
           "}");                                                                
   return; // 필터 체인 처리 중지
}

 

토큰이 조작된 경우 응답을 잘 내뱉는 것을 확인할 수 있다. 

 

심심함이 만든 예외처리였다.

반응형
저작자표시 (새창열림)

'프로젝트 > 씈크럼 프로젝트' 카테고리의 다른 글

QueryDSL 도입기  (0) 2024.02.17
쿼리 메서드 사용으로 인한 성능 개선  (1) 2024.02.09
Swagger를 배포한 상태로 사용해보기  (0) 2024.02.01
현재 스프링부트 프로젝트에 유효성 검사 진행하기  (1) 2024.01.31
'프로젝트/씈크럼 프로젝트' 카테고리의 다른 글
  • QueryDSL 도입기
  • 쿼리 메서드 사용으로 인한 성능 개선
  • Swagger를 배포한 상태로 사용해보기
  • 현재 스프링부트 프로젝트에 유효성 검사 진행하기
indeep
indeep
백준 - https://www.acmicpc.net/user/esu08259 깃허브 - https://github.com/qkrrlgus114
indeep
불편한 게 싫어
indeep
글쓰기방명록관리자
전체
오늘
어제
  • 분류 전체보기 (180)
    • 알고리즘문제 (11)
      • 백준 (10)
      • swea (1)
    • CS지식 (27)
      • HTTP 웹 지식 (4)
    • 일상 (1)
    • 스프링 강의(인프런) (4)
    • JAVA 강의(인프런) (11)
    • JAVA (8)
    • 오류해결 (31)
    • Vue (5)
    • 싸피 (4)
    • 스프링 개념 (2)
    • git 관련 (1)
    • 면접 (4)
    • 기타 (14)
    • 프로젝트 (45)
      • RESTAPI 추천 서비스 (34)
      • 씈크럼 프로젝트 (11)
    • 독서 (3)
    • 행사 || 컨퍼런스 (4)
    • 회고 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

최근 댓글

hELLO · Designed By 정상우.v4.2.2
indeep
조작된 토큰으로 SignatureException 발생 예외 처리
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.