@ExceptionHandler是Spring中用于统一处理异常的核心注解,通常与@RestControllerAdvice结合实现全局异常管理。通过定义具体异常处理方法,如NullPointerException、IllegalArgumentException及自定义BusinessException,可返回标准化响应体并设置HTTP状态码。异常应按从具体到通用的顺序排列,避免掩盖细节,并配合日志记录提升排查效率。该机制提升代码可维护性,但不处理404等非异常场景,需额外配置。合理设计异常分类与响应结构,有助于前后端协作。

在Java开发中,特别是在使用Spring或Spring Boot框架时,@ExceptionHandler 是实现统一异常处理的核心机制之一。它能帮助开发者集中管理异常响应,避免在每个控制器中重复写异常捕获逻辑,提升代码的可维护性和一致性。
什么是@ExceptionHandler
@ExceptionHandler 是Spring MVC提供的注解,用于标注在方法上,表示该方法专门用来处理特定类型的异常。当控制器中抛出匹配的异常时,Spring会自动调用这个方法进行处理。
它通常用在@ControllerAdvice或@RestControllerAdvice类中,实现全局异常拦截。
如何使用@ControllerAdvice集中处理异常
要实现全局异常处理,需要结合@ControllerAdvice 注解。它是一个增强版的@Component,能够被Spring容器扫描,并对所有控制器生效。
立即学习“Java免费学习笔记(深入)”;
以下是一个典型的统一异常处理类示例:
@RestControllerAdvice
public 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());
}
}
说明:
- @RestControllerAdvice = @ControllerAdvice + @ResponseBody,自动将返回值转为JSON格式。
- 按异常类型从具体到通用排列,避免通用异常提前捕获。
- 返回ResponseEntity可自定义HTTP状态码和响应体。
自定义业务异常与统一响应结构
实际项目中,建议定义自己的业务异常类,便于区分系统异常和业务逻辑问题。
public class BusinessException extends RuntimeException {
public BusinessException(String message) {
super(message);
}
}
然后在全局处理器中添加对应处理逻辑:
@ExceptionHandler(BusinessException.class) public ResponseEntity
这样前端可以依据code字段做统一错误提示处理,提升交互体验。
注意事项与最佳实践
使用@ExceptionHandler时应注意以下几点:
- 异常处理方法的参数可以包括Exception、HttpServletRequest等,Spring会自动注入。
- 优先处理具体的异常类型,再兜底到Exception,防止掩盖细节。
- 不要在异常处理中抛出新的受检异常,否则可能引发容器默认错误页。
- 结合日志记录(如log.error)便于排查问题。
- 对于404等非异常情况,不属于@ExceptionHandler处理范围,需通过其他方式配置。
基本上就这些。合理使用@ExceptionHandler配合@ControllerAdvice,能让Java Web应用的异常处理更清晰、更可控。关键是设计好异常分类和响应格式,做到前后端协作顺畅。不复杂但容易忽略细节。










