通过@ControllerAdvice和自定义异常类实现统一异常处理,先定义Result类封装返回格式,再创建GlobalExceptionHandler捕获BusinessException、NullPointerException等异常并转换为标准Result响应,结合@RestControllerAdvice确保接口返回格式一致,提升API健壮性。
在Spring项目中,为了保证接口返回的异常信息统一、清晰,通常需要对异常进行全局处理。通过 @ControllerAdvice 和 @ExceptionHandler 可以实现统一异常响应格式。
定义统一返回结果格式
先创建一个通用的响应体类,用于封装成功和异常时的返回数据:
public class Result
private int code;
private String message;
private T data;
public static 使用@ControllerAdvice处理异常
创建一个全局异常处理器,捕获项目中抛出的异常,并转换为统一格式返回:
@ControllerAdvice public class GlobalExceptionHandler { // 处理自定义业务异常 @ExceptionHandler(BusinessException.class) @ResponseBody public Result自定义业务异常类
为了更灵活地控制业务异常,可以定义自己的异常类:
public class BusinessException extends RuntimeException { private int code; public BusinessException(int code, String message) { super(message); this.code = code; } public int getCode() { return code; } }在业务代码中直接抛出:
if (user == null) { throw new BusinessException(404, "用户不存在"); }注意事项
确保控制器返回类型统一为 Result
对于REST API,推荐使用 @RestControllerAdvice 替代 @ControllerAdvice,自动加上@ResponseBody。
生产环境建议记录异常日志,便于排查问题。








