梳理Spring Boot中三种异常处理

在 Spring Boot 中处理异常确实有多个方式,比如使用 @ControllerAdviceBasicErrorControllerHandlerExceptionResolver等。不同方式适合不同的场景,下面是对这些方式的分析以及如何选择的建议:

🧩 1. @ControllerAdvice + @ExceptionHandler(推荐使用)

适用场景:

• 适合全局或局部地处理控制器抛出的异常。

• 适合为 REST 接口返回统一的异常结构(如 JSON)。

优点:

• 使用简单,语义明确。

• 可细粒度控制不同异常的处理逻辑。

• 与 Spring MVC 集成紧密,配合@ResponseStatus等注解效果更好。

示例:

java 复制代码
@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(ResourceNotFoundException.class)
    @ResponseStatus(HttpStatus.NOT_FOUND)
    public ErrorResponse handleNotFound(ResourceNotFoundException ex) {
        return new ErrorResponse("NOT_FOUND", ex.getMessage());
    }

    @ExceptionHandler(Exception.class)
    @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)
    public ErrorResponse handleException(Exception ex) {
        return new ErrorResponse("INTERNAL_ERROR", "Unexpected error occurred");
    }
}

🧩 2. 自定义 BasicErrorController

适用场景:

• 需要完全控制 Spring Boot 默认错误响应行为时。

• 通常用于构建统一错误页面(HTML)或更底层的 JSON 错误处理逻辑。

优点:

• 可以替换 Spring Boot 默认的 /error 映射逻辑。

• 对 WebMvc + REST + WebFlux 一致性要求高时有用。

缺点:

• 实现复杂,通常不建议自定义它,除非你确实不满意 Spring Boot 提供的默认行为。

备注:

• Spring Boot 默认的错误信息来自 DefaultErrorAttributes 和 BasicErrorController。

🧩 3. HandlerExceptionResolver(低级机制)

适用场景:

• 需要低级别控制异常解析过程,比如处理过滤器/拦截器中抛出的异常。

• 不推荐用于日常业务异常处理。

优点:

• 可用于特殊场景,如非 MVC 层的异常处理。

缺点:

• 更底层、侵入性大、可维护性差。


✅ 选择建议总结

使用方式 场景适合 是否推荐
@ControllerAdvice 统一处理控制器异常(REST 风格),前后端分离 ✅ 推荐
BasicErrorController 自定义 Spring Boot 错误响应入口,有HTML页面需求 ⚠️ 特殊需求时使用
HandlerExceptionResolver 全局底层异常控制 ❌ 不推荐常规使用

总得来说,如果是前后端分离的项目则选择@ControllerAdvice,如果是需要返回HTML错误页面选择BasicErrorController,除非有更底层的异常处理就选择HandlerExceptionResolver,但一般不建议使用。

相关推荐
阿蒙Amon32 分钟前
C#每日面试题-常量和只读变量的区别
java·面试·c#
Victor35640 分钟前
Hibernate(42)在Hibernate中如何实现分页?
后端
Victor3561 小时前
Hibernate(41)Hibernate的延迟加载和急加载的区别是什么?
后端
猪猪拆迁队1 小时前
2025年终总结-都在喊前端已死,这一年我的焦虑、挣扎与重组:AI 时代如何摆正自己的位置
前端·后端·ai编程
寻星探路1 小时前
【算法专题】滑动窗口:从“无重复字符”到“字母异位词”的深度剖析
java·开发语言·c++·人工智能·python·算法·ai
程序员小白条1 小时前
面试 Java 基础八股文十问十答第八期
java·开发语言·数据库·spring·面试·职场和发展·毕设
ConardLi1 小时前
SFT、RAG 调优效率翻倍!垂直领域大模型评估实战指南
前端·javascript·后端
萤丰信息1 小时前
从 “钢筋水泥” 到 “数字神经元”:北京 AI 原点社区重构城市进化新逻辑
java·大数据·人工智能·安全·重构·智慧城市·智慧园区
Hooray2 小时前
2026年,站在职业生涯十字路口的我该何去何从?
前端·后端
唐叔在学习2 小时前
还在申请云服务器来传输数据嘛?试试P2P直连吧
后端·python