Java异常统一处理方法详解
时间:2026-01-15 12:00:51 237浏览 收藏
偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《Java异常统一处理封装方法解析》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!
该用@ControllerAdvice,但仅适用于Spring MVC/WebFlux的控制器层异常;需配合@ExceptionHandler显式声明异常类型,设计自定义异常时应包含code、timestamp、traceId字段,推荐返回Result而非ResponseEntity,全局处理器须记录带堆栈的error日志并防范自身抛异常。

统一异常处理该不该用@ControllerAdvice
该用,但只适用于 Spring MVC 或 Spring WebFlux 的 Web 层。它不是万能兜底,@ControllerAdvice 只捕获控制器方法抛出的异常,对过滤器(Filter)、拦截器(Interceptor)、异步线程(@Async)、定时任务(@Scheduled)或全局线程池里的异常完全无效。
常见误用是把所有 try-catch 都删掉,指望 @ControllerAdvice 拦住一切——结果 NullPointerException 在 Filter 里直接 500,日志都没进统一处理器。
- 只对
@RequestMapping、@GetMapping等注解标记的 handler 方法生效 - 需配合
@ExceptionHandler显式声明要捕获的异常类型,未声明的仍会向上冒泡 - 若多个
@ControllerAdvice存在,按@Order或类名排序,顺序错可能导致覆盖
自定义异常类该怎么设计字段
别只塞一个 message。生产环境需要快速定位问题,至少保留三个核心字段:code(业务码)、timestamp(毫秒时间戳)、traceId(链路 ID)。其中 traceId 必须从 MDC 或请求上下文透传,不能在异常构造时硬编码生成。
code 推荐用整数而非字符串——便于前端 switch 判断,也避免拼写不一致(比如 "USER_NOT_FOUND" 和 "user_not_found")。错误码建议分段设计,例如 100101:前两位 10 表示用户模块,中间两位 01 表示查询类错误,末两位 01 表示具体子错误。
- 不要继承
RuntimeException后就不管父类构造函数,务必显式调用super(message, cause)保留原始堆栈 - 避免在自定义异常中重写
toString()或printStackTrace(),干扰日志框架行为 - 字段全部设为
final,防止被序列化/反序列化篡改
ResponseEntity 还是直接 return Result
直接 return Result 更干净。Spring Boot 默认配置下,只要控制器方法返回值不是 ResponseEntity,就会被 @ResponseBody 处理器自动包装成 JSON 响应体,状态码默认 200。
用 ResponseEntity 的唯一合理场景是:你需要动态控制 HTTP 状态码(比如成功时返回 201,或某些业务异常要返回 409),且这个状态码无法通过全局异常处理器统一映射。否则,硬塞 ResponseEntity.ok().body(new Result(...)) 只会让代码变啰嗦,还容易漏掉 headers 或 status 设置。
- 统一异常处理器中用
ResponseEntity.status(code).body(result)控制状态码即可 - 控制器方法签名保持简洁,如
public ResultgetUser(@PathVariable Long id) - 若强行用
ResponseEntity,记得所有分支都显式指定 status,否则 null body 会触发 200 OK + 空响应体,前端难排查
全局异常处理器里要不要记录 error 日志
要,但必须记录原始异常(throwable),而不是只打 result.getMessage()。很多团队只记了 “用户不存在”,却没记是哪行代码、哪个参数、什么 SQL 导致的,查问题时只能靠猜。
更关键的是:日志级别必须用 error,且必须包含完整堆栈(logger.error("biz error", e)),不能只写 logger.error(e.getMessage())——后者会丢掉堆栈和 cause 链。
- 敏感信息如密码、身份证号、token 要在日志输出前脱敏,可借助 Logback 的
PatternLayout+ 自定义Converter - 避免在异常处理器里做耗时操作(如发邮件、调远程接口),可能拖慢整个请求响应
- 如果用了 Sentry 或 SkyWalking,确保
throwable被正确传递,否则告警里看不到堆栈
最常被忽略的一点:全局异常处理器本身也可能抛异常。比如 JSON 序列化失败、NPE 在构建 Result 时发生——这时 Spring 会 fallback 到默认错误页,你的统一逻辑彻底失效。务必在处理器内加最外层 try-catch 并记录原始异常。
终于介绍完啦!小伙伴们,这篇关于《Java异常统一处理方法详解》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
118 收藏
-
380 收藏
-
427 收藏
-
270 收藏
-
135 收藏
-
108 收藏
-
497 收藏
-
127 收藏
-
223 收藏
-
481 收藏
-
181 收藏
-
187 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习