inflearn logo
강의

講義

知識共有

[初級]撮って食べよう!コトリンとSpring Security + JWTで会員登録をする

2.5。 ExceptionHandlerの作成

토큰에서 예외 발생시 처리

245

leeyr0412

投稿した質問数 1

0

안녕하세요 강사님, 좋은 강의 잘 듣고 있습니다.

따라하던 중 토큰을 잘못 입력했을 경우 403 Forbidden 에러가 발생하는데 이 에러의 경우는 RestControllerAdvice 에서 처리를 할 수 없는건가요??
이 경우에도 Response형태를 통일 시키고 싶은데 어떻게 하면 될까요..?

kotlin spring-boot jpa spring-security jwt

回答 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

토큰 관련 예외처리를 RestControllerAdvice에서 처리하고자 할 때, Spring Boot에서는 @ControllerAdvice 또는 @RestControllerAdvice를 사용하여 전역적인 예외 처리를 구성할 수 있습니다. 하지만 403 Forbidden 에러 같은 인증 및 인가와 관련된 예외는 Spring Security의 필터 체인에서 발생하기 때문에, 단순히 @RestControllerAdvice로 처리하기 어려울 수 있습니다.

이러한 예외 상황을 처리하려면 Spring Security의 예외 처리 메커니즘을 사용해야 합니다. 특히, Spring Security에 커스텀 엔트리 포인트를 구현하거나 액세스 거부 핸들러를 정의하여 이러한 상황을 처리할 수 있습니다.

예를 들어, JwtAuthenticationEntryPoint 클래스를 구현하여 인증 실패 시 커스텀 응답을 반환하도록 설정할 수 있습니다.

@Component
public class JwtAuthenticationEntryPoint implements AuthenticationEntryPoint {

    @Override
    public void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authException) throws IOException, ServletException {
        // 여기에서 custom response를 설정합니다.
        response.sendError(HttpServletResponse.SC_FORBIDDEN, "Unauthorized");
    }
}

또한, WebSecurityConfigurerAdapter에서 이를 등록해주어야 합니다.

@Override
protected void configure(HttpSecurity http) throws Exception {
    http
        .csrf().disable()
        .exceptionHandling()
        .authenticationEntryPoint(jwtAuthenticationEntryPoint)
        // 나머지 구성
}

이와 같이 설정하면, Spring Security가 처리하는 인증 예외 상황에서도 커스텀 응답을 반환할 수 있습니다.

이러한 내용은 Spring Security project pageSpring Boot Reference Documentation에서 보다 자세히 확인할 수 있습니다.

패키지 구분에 대해 궁금한게 있습니다

0

8

1

스프링부트 서버 에러나요

0

17

1

74. 데이터 캐시 - 1 (이론) 강의 영상 누락

0

26

1

2026.04에 추가된 강의 시청 불가

0

27

1

Service Create/Update Record 운용과 Delete Record 미운용의 차이 질문

0

18

1

인가 코드 발급(프론트 vs 백)

0

28

2

validation 추가하기에 대해 질문

0

105

1

로그인 후 Token 발행 시 postman 에러메시지

0

156

1

unique 작성법

0

151

1

4.1 마지막 회원가입 실행되지만 빈화면 뜸

0

223

3

4.1강 마지막 회원가입 실행

0

154

1

2.4강에서 1:18초쯤에 <T>를하고 뭔가 추가하는 작업

0

177

2

class 와 data class

0

182

1

안녕하세요 선생님 rememberme 질문드립니다..!

0

245

1

Next Lv 강의에 대해서 계획중이신게 있을까요?

0

285

1

테이블 create문

0

182

1

DTO 생성 과정에서 궁금한 점이 있어요!!

0

560

3

2.5강에서 포스트맨 오류와 전에 실습한 내용에 대해 질문 드립니다

0

592

2

TokenProvider의 Key 관련하여 질문이 있습니다.

0

378

1

스프링 시큐리티 예외 RestControllerAdvice로 처리

0

443

1

1 : N 필드 `memberRole` 에 @OneToMany 옵션 cascade 미사용, 컬랙션 null 초기화 에 대한 질문입니다.

0

406

2

loginId는 왜 변경이 안될까요?

0

420

1

memberRole필드 질문이요~

0

494

1

Validation 관련해서 질문드립니다.

1

795

2