@ExceptionHandler是Spring中用于统一处理异常的核心注解,通常与@RestControllerAdvice结合实现全局异常管理。通过定义具体异常处理方法,如NullPointerException、IllegalArgumentException及自定义BusinessException,可返回标准化响应体并设置HTTP状态码。异常应按从具体到通用的顺序排列,避免掩盖细节,并配合日志记录提升排查效率。该机制提升代码可维护性,但不处理404等非异常场景,需额外配置。合理设计异常分类与响应结构,有助于前后端协作。
在Java开发中,特别是在使用Spring或Spring Boot框架时,@ExceptionHandler 是实现统一异常处理的核心机制之一。它能帮助开发者集中管理异常响应,避免在每个控制器中重复写异常捕获逻辑,提升代码的可维护性和一致性。
@ExceptionHandler 是Spring MVC提供的注解,用于标注在方法上,表示该方法专门用来处理特定类型的异常。当控制器中抛出匹配的异常时,Spring会自动调用这个方法进行处理。
它通常用在@ControllerAdvice或@RestControllerAdvice类中,实现全局异常拦截。
要实现全局异常处理,需要结合@ControllerAdvice 注解。它是一个增强版的@Component,能够被Spring容器扫描,并对所有控制器生效。
以下是一个典型的统一异常处理类示例:
@RestControllerAdvicepublic class GlobalExceptionHandler { @ExceptionHandler(NullPointerException.class) public ResponseEntity
handleNullPointer(NullPointerException e) { return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR) .body("发生了空指针异常:" + e.getMessage()); } @ExceptionHandler(IllegalArgumentException.class) public ResponseEntity handleIllegalArgument(IllegalArgumentException e) { return ResponseEntity.status(HttpStatus.BAD_REQUEST) .body("参数不合法:" + e.getMessage()); } @ExceptionHandler(Exception.class) public ResponseEntity handleGeneralException(Exception e) { return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR) .body("系统发生未知错误:" + e.getMessage()); } }
说明:
实际项目中,建议定义自己的业务异常类,便于区分系统异常和业务逻辑问题。
public class BusinessException extends RuntimeException {
public BusinessException(String message) {
super(message);
}
}
然后在全局处理器中添加对应处理逻辑:
@ExceptionHandler(BusinessException.class) public ResponseEntity
这样前端可以依据code字段做统一错误提示处理,提升交互体验。
使用@ExceptionHandler时应注意以下几点:
基本上就这些。合理使用@ExceptionHandler配合@ControllerAdvice,能让Java Web应用的异常处理更清晰、更可控。关键是设计好异常分类和响应格式,做到前后端协作顺畅。不复杂但容易忽略细节。