분류 전체보기
스프링 MVC 2 - API 예외 처리 - 시작
스프링 MVC 2 - API 예외 처리 - 시작
2022.09.28API 예외 처리 - 시작 목표 API 예외 처리는 어떻게 해야할까? HTML 페이지의 경우 지금까지 설명했던 것 처럼 4xx, 5xx와 같은 오류 페이지만 있으면 대부분의 문제를 해결할 수 있다. 그런데 API의 경우에는 생각할 내용이 더 많다. 오류 페이지는 단순히 고객에게 오류 화면을 보여주고 끝이지만, API는 각 오류 상황에 맞는 오류 스펙을 정하고, JSON으로 데이터를 내려주어야 한다. 지금부터 API의 경우 어떻게 예외 처리를 하면 좋은지 알아보자. API도 오류 페이지에서 설명했던 것 처럼 처음으로 돌아가서 서블릿 오류 페이지 방식을 사용해보자. WebServerCustomizer 다시 동작 WebServerCustomizer 가 다시 사용되도록 하기 위해 @Component 애노테이션에..
스프링 MVC 2 - 정리(예외 처리와 오류 페이지)
스프링 MVC 2 - 정리(예외 처리와 오류 페이지)
2022.09.28정리(예외 처리와 오류 페이지) 프로젝트 생성 서블릿 예외 처리 - 시작 Exception(예외) response.sendError(Http 상태 코드, 오류 메시지) 톰캣이 기본으로 오류 화면을 제공함. 그러나 오류 화면이 너무 별로임. 서블릿 예외 처리 - 오류 화면 제공 스프링 부트는 WebserverFactoryCustomizer를 가지고 원하는 오류페이지를 등록 할 수 잇었다. response.sendError(404) : errorPage404 호출 response.sendError(500) : errorPage500 호출 RuntimeException 또는 그 자식 타입의 예외 : errorPageEx 호출 서블릿 예외 처리 - 오류 페이지 작동 원리 예외 발생 흐름 WAS(여기까지 전파) ..
스프링 MVC 2 - 스프링 부트 - 오류 페이지2
스프링 MVC 2 - 스프링 부트 - 오류 페이지2
2022.09.28스프링 부트 - 오류 페이지2 BasicErrorController가 제공하는 기본 정보들 BasicErrorController 컨트롤러는 다음 정보를 model에 담아서 뷰에 전달한다. 뷰 템플릿은 이 값을 활용해서 출력할 수 있다. * timestamp: Fri Feb 05 00:00:00 KST 2021 * status: 400 * error: Bad Request * exception: org.springframework.validation.BindException * trace: 예외 trace * message: Validation failed for object='data'. Error count: 1 * errors: Errors(BindingResult) * path: 클라이언트 요청 경..
스프링 MVC 2 - 스프링 부트 - 오류 페이지1
스프링 MVC 2 - 스프링 부트 - 오류 페이지1
2022.09.27스프링 부트 - 오류 페이지1 지금까지 예외 처리 페이지를 만들기 위해서 다음과 같은 복잡한 과정을 거쳤다. WebServerCustomizer를 만들고 예외 종류에 따라서 ErrorPage를 추가하고 예외 처리용컨트롤러 ErrorPageController를 만듦 스프링 부트는 이런 과정을 모두 기본으로 제공한다. ErrorPage를 자동으로 등록한다. 이때 /error라는 경로로 기본 오류 페이지를 설정한다. new ErrorPage("/error"), 상태코드와 예외를 설정하지 않으면 기본 오류 페이지로 사용된다. 서블릿 밖으로 예외가 발생하거나, response.sendError(...)가 호출되면 모든 오류는 /error를 호출하게 된다. BasicErrorController라는 스프링 컨트롤러를..
스프링 MVC 2 - 서블릿 예외 처리 - 인터셉터
스프링 MVC 2 - 서블릿 예외 처리 - 인터셉터
2022.09.27서블릿 예외 처리 - 인터셉터 인터셉터 중복 호출 제거 LogInterceptor - DispatcherType 로그 추가 앞서 필터의 경우에는 필터를 등록할 때 어떤 DispatcherType인 경우에 필터를 적용할 지 선택할 수 있었다. 그런데 인터셉터는 서블릿이 제공하는 기능이 아니라 스프링이 제공하는 기능이다. 따라서 DispatcherType과 무관하게 항상 호출된다. 대신에 인터셉터는 다음과 같이 요청 경로에 따라서 추가하거나 제외하기 쉽게 되어 있기 때문에, 이러한 설정을 사용해서 오류 페이지 경로를 excludePathPatterns를 사용해서 뺴주면 된다. 인터셉터와 중복으로 처리되지 않기위해 LogFilter()의 @Bean에 주석을 달아두자. 여기에서 /error-page/**를 제거..
스프링 MVC 2 - 서블릿 예외 처리 - 필터
스프링 MVC 2 - 서블릿 예외 처리 - 필터
2022.09.27서블릿 예외 처리 - 필터 목표 예외 처리에 따른 필터와 인터셉터 그리고 서블릿이 제공하는 DispatchType 이해하기 예외 발생과 오류 페이지 요청 흐름 1. WAS(여기까지 전파) 컨트롤러(/errorpage/500) -> View 오류가 발생하면 오류 페이지를 출력하기 위해 WAS 내부에서 다시 한번 호출이 발생한다. 이때 필터, 서블릿, 인터셉터도 모두 다시 호출된다. 그런데 로그인 인증 체크 같은 경우를 생각해보면, 이미 한번 필터나, 인터셉터에서 로그인 체크를 완료했다. 따라서 서버 내부에서 오류 페이지를 호출한다고 해서 해당 필터나 인터셉터가 한번 더 호출되는 것은 매우 비효율적이다. 결국 클라이언트로 부터 발생한 정상 요청인지, 아니면 오류 페이지를 출력하기 위한 내부 요청인지 구분할 ..