티스토리 뷰
개요
Spring Framework 3.2부터 @ControllerAdvice가 소개되었다. 이를 통해 우리는 특정 컨트롤러에 종속되지 않은 전역 범위에서 발생하는 특정 예외에 대한 처리를 한 곳에서 작성할 수 있게 되었다. 본 글에서는 이 방법을 설명하고자 한다.
목표
- 특정 컨트롤러에 종속되지 않은 전역 예외 처리 로직을 작성한다.
 
사전 지식
특정 예외를 처리하는 ExceptionHandler 작성
@ControllerAdvice
@Order(Ordered.HIGHEST_PRECEDENCE)
public class SomeExceptionHandler {
    @ExceptionHandler(SomeException.class)
    @ResponseBody
    public ResponseEntity<?> handleSomeException(HttpServletRequest request, SomeException ex) {
        // SomeException 예외 발생시 처리 로직 작성
        return new ResponseEntity<>(ex, HttpStatus.BAD_REQUEST);
    }
    @ExceptionHandler(Exception.class)
    @ResponseBody
    public ResponseEntity<?> handleException(HttpServletRequest request, Exception ex) {
        // Exception 예외 발생시 공통 처리 로직 작성
        return new ResponseEntity<>(ex, HttpStatus.BAD_REQUEST);
    }
}
@ControllerAdvice를 클래스 레벨에 부여하면 @Controller 빈을 돕는 빈으로 기능할 수 있다. 예를 들어 모든 컨트롤러 제어 범위에서 특정 예외가 발생하면 공통적인 처리 로직을 작성할 수 있다.@Order를 클래스 레벨에 부여하면 @ControllerAdvice 빈 간의 우선순위를 조정할 수 있다. @ControllerAdvice 빈이 여러 개일 때 어떤 것을 우선할지 결정할 수 있다. Ordered.HIGHEST_PRECEDENCE는 최우선 순위를 의미한다.@ExceptionHandler를 메써드 레벨에 부여하면 특정 예외가 발생했을 때의 처리 로직을 작성할 수 있다.@ResponseBody를 메써드 레벨에 부여하면 특정 뷰가 아닌 메시지 바디를 반환할 수 있다. 즉, REST API의 응답 형태로 예외 처리 로직의 결과를 반환하겠다는 것이다.ResponseEntity오브젝트는 HTTP 응답 코드, 응답 헤더, 응답 바디 모두를 담을 수 있는 만능 객체이다. 즉, REST API의 응답을 자유롭게 담을 수 있다.
특정 예외 발생 예
@Service
public class SomeService {
    public void doSomeBusinessLogic {
        // 특정 조건에 따라 SomeException 예외 발생
        throw new SomeException("SomeError Occured.");
        ...
    }
}
- @Controller에 의해 호출되는 모든 범위에서 위와 같이 SomeException 예외를 발생시키면 앞서 작성한 @ControllerAdvice 빈에 의해 해당 예외에 대한 특정 예외 응답을 수행할 수 있다.
 
참고 글
					댓글
						
					
					
					
				
			
									최근에 올라온 글
									
							
								
								
									최근에 달린 댓글
									
							
								
								- Total
 
- Today
 
- Yesterday
 
									링크
									
							
								
								
									TAG
									
							
								
								- graylog
 - spring
 - maven
 - JavaScript
 - Spring Boot
 - bootstrap
 - Eclipse
 - 알뜰폰
 - Kendo UI
 - jstl
 - MySQL
 - Spring MVC 3
 - Tomcat
 - chrome
 - 태그를 입력해 주세요.
 - 평속
 - 자전거
 - java
 - JHipster
 - kotlin
 - DynamoDB
 - Docker
 - 구동계
 - jsp
 - 로드 바이크
 - 로드바이크
 - node.js
 - CentOS
 - jpa
 - Kendo UI Web Grid
 
| 일 | 월 | 화 | 수 | 목 | 금 | 토 | 
|---|---|---|---|---|---|---|
| 1 | ||||||
| 2 | 3 | 4 | 5 | 6 | 7 | 8 | 
| 9 | 10 | 11 | 12 | 13 | 14 | 15 | 
| 16 | 17 | 18 | 19 | 20 | 21 | 22 | 
| 23 | 24 | 25 | 26 | 27 | 28 | 29 | 
| 30 | 
									글 보관함
									
							
					