토큰에서 예외 발생시 처리
245
1 asked
안녕하세요 강사님, 좋은 강의 잘 듣고 있습니다.
따라하던 중 토큰을 잘못 입력했을 경우 403 Forbidden 에러가 발생하는데 이 에러의 경우는 RestControllerAdvice 에서 처리를 할 수 없는건가요??
이 경우에도 Response형태를 통일 시키고 싶은데 어떻게 하면 될까요..?
Answer 1
0
안녕하세요, 인프런 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 page와 Spring Boot Reference Documentation에서 보다 자세히 확인할 수 있습니다.
패키지 구분에 대해 궁금한게 있습니다
0
11
1
스프링부트 서버 에러나요
0
17
1
74. 데이터 캐시 - 1 (이론) 강의 영상 누락
0
29
1
2026.04에 추가된 강의 시청 불가
0
28
1
Service Create/Update Record 운용과 Delete Record 미운용의 차이 질문
0
20
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
407
2
loginId는 왜 변경이 안될까요?
0
420
1
memberRole필드 질문이요~
0
494
1
Validation 관련해서 질문드립니다.
1
795
2

