인프런 커뮤니티 질문&답변

aole님의 프로필 이미지

작성한 질문수

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

예제로 구현하는 파일 업로드, 다운로드

ExceptionResolver 내에서 sendError 호출

작성

·

55

0

안녕하세요!

 

제가 질문의 의도를 명확히 드러내지 못한 것 같아 내용을 추가하여 재 질문 드립니다.

 

https://www.inflearn.com/community/questions/1369485/exceptionresolver-%EC%97%90%EB%9F%AC-%ED%95%B4%EA%B2%B0%EC%97%90-%EA%B4%80%ED%95%98%EC%97%AC-%EC%A7%88%EB%AC%B8%EC%9D%B4-%EC%9E%88%EC%8A%B5%EB%8B%88%EB%8B%A4

 

<제가 생각한 json 결과>

 

{
    "timestamp": "2024-09-07T16:52:16.664+00:00",
    "status": 400,
    "error": "Bad Request",
    "path": "/api/members/bad"
}

 

resolver에서 IllegalArgumentException을 해결을 하였고 sendError로 흐름을 바꾸었으니 순수 sendError(400)의 결과인 위 json과 같이 나와야 한다고 생각하였습니다.


<흐름도>

Controller 에서 IllegalArgumentException 발생 -> ExceptionResolver 실행 -> IllegalArgumentException 해결 후 sendError로 변경 -> BasicController 호출 후 sendError의 결과인 위의 json 반환

 

따라서 에러를 해결하였기 때문에 IllegalArgumentException 정보는 없고 sendError 정보만 있다고 생각합니다. 실제 출력에는 어찌 IllegalArgumentException 정보가 json에 출력되는지 궁금합니다.

 

에러를 해결 했더라도 그 정보를 다른 객체로 가지고 있고 나중에 활용하는 것 일까요??

 

좋은 강의 만들어 주셔서 감사합니다.

답변 2

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. aole님

스프링 부트가 기본으로 제공하는 첫번째 HandlerExceptionResolver가 있습니다.

바로 DefaultErrorAttributes라는 것인데요.

여기서 발생한 예외를 보관해둡니다 🙂

request.setAttribute(ERROR_INTERNAL_ATTRIBUTE, ex);

우리가 사용한 MyHandlerExceptionResolver는 그 다음으로 적용됩니다.

DefaultErrorAttributes의 코드를 보시면 바로 이해가 되실거에요.

감사합니다.

0

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

aole님의 질문에 대해 답변드립니다.

ExceptionResolver 내에서 sendError를 호출하더라도, Spring Framework는 내부적으로 발생한 예외 정보를 관리하고 있으며, 그 정보를 바탕으로 에러 응답을 구성할 수 있습니다. sendError 메소드는 HTTP 응답 상태 코드와 메시지를 클라이언트에게 전달하기 위한 Servlet API의 일부입니다. 하지만 Spring에서는 이를 더 확장하여, 에러가 발생했을 때의 처리를 더 섬세하게 할 수 있는 여러 메커니즘을 제공합니다.

예외가 발생하고 그것이 ExceptionResolver에 의해 처리된 후에도, Spring은 예외 정보 및 발생한 컨텍스트를 ErrorAttributes라는 형태로 관리할 수 있습니다. 이는 예외 처리 시, 기본적으로 제공되는 /error 매핑을 통해 일관된 에러 응답 구조를 제공하는 데에 사용됩니다. 이러한 메커니즘을 통해, 실제로 예외 처리 로직에서 사용자 정의 에러 정보를 추가하여 응답을 보강할 수도 있습니다.

IllegalArgumentException 정보가 결과 JSON에 포함되는 것은 Spring이 내부적으로 예외 정보를 담고 있는 ErrorAttributes를 사용해 최종 에러 응답을 구성하기 때문일 수 있습니다. sendError 호출은 응답 상태 코드를 변경하지만, Spring의 에러 처리 메커니즘은 이와 별개로 작동하여, 예외의 내용을 에러 응답에 포함시킬 수 있습니다.

실제로 Spring Boot에서 제공하는 기본 에러 처리 방식을 변경하거나, 예외에 대한 자세한 정보를 제공하고 싶다면, ErrorController를 직접 구현하거나 ErrorAttributes 타입의 빈을 추가하여 기본 동작을 오버라이드할 수 있습니다.

여러분이 작성한 예외 처리 코드나 Spring의 설정에 따라 실제 에러 응답에 포함되는 정보가 달라질 수 있으니, 올려주신 흐름도와 코드를 바탕으로 구체적인 에러 응답 구조와 원하는 응답을 어떻게 맞출 수 있을지 고민해 보시면 좋을 것 같습니다.

좋은 질문 감사드립니다.

aole님의 프로필 이미지

작성한 질문수

질문하기