인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

tjrans303님의 프로필 이미지
tjrans303

작성한 질문수

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

서블릿 예외 처리 - 인터셉터

인터셉터 예외처리

작성

·

78

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

log.error("afterCompletion error!!", ex);

여기서 왜 ex에 대한 정보는 출력이 되지 않나요?
[질문 내용]
여기에 질문 내용을 남겨주세요.

답변 3

0

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

안녕하세요. tjrans303님

ex 예외가 출력된 것이 맞습니다.

이 경우 해당 라인이 아니라 그 다음 라인에 예외 트레이스가 출력됩니다 🙂

감사합니다.

0

일단 저렇게 하면 afterCompletion error!! 라고만 뜰겁니다.
log.error 사용법에 대해서 다시 공부해보세요 {}를 괜히 입력하는게 아닙니다.

그리고 ex라고 넣어봤자 클래스 참조값만 뜰겁니다. 이부분은 자바에 대해서 공부하셔야합니다.

ex.getMessage를 출력하시던가, Stream을 활용하여 ex.printStacktrace로 String을 만들어 파라미터로 넘겨야합니다.

0

안녕하세요, 인프런 AI 인턴입니다. tjrans303님께서 질문하신 “인터셉터 예외처리”에 대한 답변을 드리겠습니다.

인터셉터에서 예외를 적절하게 처리하는 방법에 대해 설명드리겠습니다. 일반적으로 스프링에서는 예외가 발생했을 때 HandlerExceptionResolver를 활용하여 예외를 처리합니다. 예외를 처리하는 과정에서 HTTP 응답을 커스터마이징할 수 있습니다.

먼저, 인터셉터에서 응답 코드 설정하기 관련하여 궁금하시다면, response.setStatus() 메서드를 통해 직접 상태 코드를 변경할 수 있습니다. 이것을 활용하여 원하는 상태 코드를 반환하도록 설정할 수 있습니다.

또한, 일반적으로 예외가 발생하면 sendError() 메서드로 상태 코드를 설정할 수 있습니다. 하지만 이렇게 설정한 에러 코드가 기대하는 대로 작동하지 않을 때는, 인터셉터 내부에서 명시적으로 상태 코드를 지정해야 할 수도 있으며, 예외 처리를 위한 별도 설정을 고려해야 합니다.

자세한 내용은, 다음의 유사한 질문 답변도 참고하시면 도움이 될 것입니다:
1. 인터셉터 활용 방법 질문
2. 인터셉터 아작스 요청 처리 관련

이 링크들에서 비슷한 상황의 해결법을 참고하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

tjrans303님의 프로필 이미지
tjrans303

작성한 질문수

질문하기