예외 처리는 강력하고 사용자 친화적인 애플리케이션을 구축하는 데 중요한 부분입니다. Spring Boot에서는 애플리케이션이 안정적으로 유지되고 사용자에게 의미 있는 피드백을 제공할 수 있도록 다양한 방법으로 예외를 처리할 수 있습니다. 이 가이드에서는 사용자 정의 예외, 전역 예외 처리, 유효성 검사 오류 및 프로덕션 모범 사례를 포함하여 예외 처리에 대한 다양한 전략을 다룹니다.
예외는 프로그램의 정상적인 흐름을 방해하는 이벤트입니다. 다음과 같이 나눌 수 있습니다:
사용자 정의 예외 클래스를 생성하면 애플리케이션의 특정 오류 조건을 처리하는 데 도움이 됩니다.
package com.example.SpringBootRefresher.exception; public class DepartmentNotFoundException extends RuntimeException { public DepartmentNotFoundException(String message) { super(message); } }
@ExceptionHandler 주석:
컨트롤러 클래스에서 예외를 처리하는 메서드를 정의할 수 있습니다.
package com.example.SpringBootRefresher.controller; import com.example.SpringBootRefresher.exception.DepartmentNotFoundException; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class DepartmentController { @GetMapping("/department") public String getDepartment() { // Simulate an exception throw new DepartmentNotFoundException("Department not found!"); } @ExceptionHandler(DepartmentNotFoundException.class) public ResponseEntity<String> handleDepartmentNotFoundException(DepartmentNotFoundException ex) { return new ResponseEntity<>(ex.getMessage(), HttpStatus.NOT_FOUND); } }
전역적으로 예외를 처리하려면 @ControllerAdvice와 중앙 집중식 예외 처리기를 사용할 수 있습니다.
package com.example.SpringBootRefresher.error; import com.example.SpringBootRefresher.entity.ErrorMessage; import com.example.SpringBootRefresher.exception.DepartmentNotFoundException; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.ResponseStatus; import org.springframework.web.context.request.WebRequest; import org.springframework.web.servlet.mvc.method.annotation.ResponseEntityExceptionHandler; @ControllerAdvice @ResponseStatus public class CustomResponseEntityExceptionHandler extends ResponseEntityExceptionHandler { @ExceptionHandler(DepartmentNotFoundException.class) public ResponseEntity<ErrorMessage> handleDepartmentNotFoundException(DepartmentNotFoundException exception, WebRequest request) { ErrorMessage message = new ErrorMessage( HttpStatus.NOT_FOUND.value(), exception.getMessage(), request.getDescription(false) ); return ResponseEntity.status(HttpStatus.NOT_FOUND) .body(message); } @ExceptionHandler(Exception.class) public ResponseEntity<ErrorMessage> handleGlobalException(Exception exception, WebRequest request) { ErrorMessage message = new ErrorMessage( HttpStatus.INTERNAL_SERVER_ERROR.value(), exception.getMessage(), request.getDescription(false) ); return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR) .body(message); } }
오류 메시지를 구성하려면 표준 오류 응답 클래스를 정의하세요.
package com.example.SpringBootRefresher.entity; public class ErrorMessage { private int statusCode; private String message; private String description; public ErrorMessage(int statusCode, String message, String description) { this.statusCode = statusCode; this.message = message; this.description = description; } // Getters and setters public int getStatusCode() { return statusCode; } public void setStatusCode(int statusCode) { this.statusCode = statusCode; } public String getMessage() { return message; } public void setMessage(String message) { this.message = message; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } }
Spring Boot는 Bean 유효성 검사(JSR-380)와 잘 통합됩니다. 유효성 검사 오류를 전역적으로 처리하려면 @ControllerAdvice를 사용하세요.
package com.example.SpringBootRefresher.error; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.validation.FieldError; import org.springframework.web.bind.MethodArgumentNotValidException; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.ResponseStatus; import org.springframework.web.context.request.WebRequest; import java.util.HashMap; import java.util.Map; @ControllerAdvice @ResponseStatus public class ValidationExceptionHandler extends ResponseEntityExceptionHandler { @ExceptionHandler(MethodArgumentNotValidException.class) public ResponseEntity<Map<String, String>> handleValidationExceptions(MethodArgumentNotValidException ex) { Map<String, String> errors = new HashMap<>(); ex.getBindingResult().getAllErrors().forEach((error) -> { String fieldName = ((FieldError) error).getField(); String errorMessage = error.getDefaultMessage(); errors.put(fieldName, errorMessage); }); return new ResponseEntity<>(errors, HttpStatus.BAD_REQUEST); } }
간단한 경우 @ResponseStatus로 예외 클래스에 주석을 달아 HTTP 상태 코드를 지정할 수 있습니다.
package com.example.SpringBootRefresher.exception; import org.springframework.http.HttpStatus; import org.springframework.web.bind.annotation.ResponseStatus; @ResponseStatus(HttpStatus.NOT_FOUND) public class DepartmentNotFoundException extends RuntimeException { public DepartmentNotFoundException(String message) { super(message); } }
Spring Boot의 예외 처리에는 오류를 효과적으로 관리하기 위해 @ExceptionHandler, @ControllerAdvice 및 @ResponseStatus와 같은 주석을 사용하는 작업이 포함됩니다. 사용자 지정 예외를 만들고, 유효성 검사 오류를 처리하고, 모범 사례를 따르면 오류를 적절하게 처리하고 사용자에게 의미 있는 피드백을 제공하는 강력한 애플리케이션을 구축할 수 있습니다. Java 17 기능을 사용하면 애플리케이션이 Java 생태계의 최신 개선 사항을 활용할 수 있습니다.
위 내용은 스프링 부트의 예외 처리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!