베어_
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)

블로그 메뉴

    공지사항

    인기 글

    태그

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

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    프로젝트 기록

    커스텀 예외 처리와 NestedServletExceeption

    2023. 7. 25. 04:02

    🔍 문제 상황

    컨트롤러 테스트를 하던 중 RestControllerAdvice를 이용하여 커스텀 예외 처리가 되어야 하는 부분에서
    UnverifiedException이 아닌 NestedServletException이 발생하는 문제가 발생하였다. 예외 처리를 하고 있는 Service 코드는 다음과 같다.

    @Override
    public User login(UserDTO.loginForm form) {
        User user = userRepository.findByEmail(form.getEmail()).orElseThrow(() -> new NotFoundException(ErrorCode.NOT_FOUND_USER));
    
        if(!user.getPassword().equals(form.getPassword())) {
            throw new InvalidPasswordException(ErrorCode.INVALID_PASSWORD);
        }
    
        if(!user.isVerified()) {
            throw new UnverifiedException(ErrorCode.UNVERIFIED_USER);
        }
    
        return user;
    }

    예외 처리는 @RestControllerAdvice와 @ExceptionHandler를 이용해서 예외가 터지면 전역적으로 처리할 수 있도록 코드를 작성한 상태였다.

    @Slf4j
    @RestControllerAdvice
    public class GeneralExceptionHandler { }

     

    문제 원인

    NestedServletException은 서블릿에서 모든 예외를 처리할 수 있도록 제공하고 있는 클래스이다. 커스텀 예외를 처리하기 위해 InvalidVerificationCodeException이라는 클래스를 만들었는데, 이를 위한 핸들러 추가를 하지 않아 발생한 문제였다.

     

    문제 해결

    다음과 같이 핸들러를 restControolerAdvice 클래스에 추가함으로써 해결할 수 있었다.

    @Slf4j
    @RestControllerAdvice
    public class GeneralExceptionHandler { 
        /**
         * 이메일 인증 코드가 부적절한 경우
         */
        @ExceptionHandler(value = { InvalidVerificationCodeException.class })
        protected ResponseEntity<ApiResponse> handleInvalidVerificationCodeException(InvalidVerificationCodeException e) {
            log.error("InvalidPasswordException", e);
            ApiResponse errorResponse = ApiResponse.of(HttpStatus.BAD_REQUEST.toString(), e.getMessage());
            return ResponseEntity.status(e.getErrorCode().getHttpStatus())
                    .body(errorResponse);
        }
    }

     

    NestedSservletException의 예외 해결 추가 방법

    1. try-catch를 이용한다.
    try {
        mockMvc.perform()
        ...
    } catch (NestedServletException e) {
        throw e.getCause();    
    }
    1. org.assertj.core.api.Assertions.assertThatThrownBy를 사용한다.
    assertThatThrownBy(() -> mockMvc.perform(post("/login")
                .content(objectMapper.writeValueAsString(request))
                .contentType(MediaType.APPLICATION_JSON)
        )
        .andDo(print()))
        .hasCause(new UnverifiedException(ErrorCode.UNVERIFIED_USER));
    저작자표시 비영리 변경금지 (새창열림)
      '프로젝트 기록' 카테고리의 다른 글
      • JWT 토큰 만료 에러 분석
      • OSIV 필터와 지연로딩 에러
      • [Debug] JWT토큰 디버그
      • [리팩토링] Pageable을 이용한 페이징
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바