news 2026/6/10 17:28:51

异常处理框架设计:全局异常捕获与统一错误码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
异常处理框架设计:全局异常捕获与统一错误码

异常处理是系统的安全气囊。

平时没有存在感,但碰撞发生的瞬间,马上弹出,在崩溃边缘托住一切。

许多项目初期为求速度,拆掉气囊。于是 Controller 里 try-catch 泛滥,前端报错五花八门,代码的混乱,本质是协作防线的失守。

构建异常处理框架,不为优雅,是为活下去。

告别裸奔

没有框架的保护,每一行代码都在裸奔。

开发者陷入防御性编程的焦虑中。为了防止崩溃,在每个方法里小心翼翼地包裹try-catch

这种焦虑,带来了三个恶果:

  • 冗余:样板代码掩盖了逻辑,噪音淹没了信号。

  • 混乱:返回格式随心所欲,协作成本极高。

  • 泄露:堆栈裸奔,等于把家底亮给黑客。

我们需要一个漏斗。

异常处理前后对比

不管业务逻辑抛出什么牛鬼蛇神,经过这个漏斗,流出来的必须是标准、干净的 JSON。

这就是全局异常处理的核心价值:把混乱留在内部,把秩序留给外界。

立法:错误码

治理混乱,先立法。

错误码,就是协议。是后端与前端、与用户之间,白纸黑字的契约。

拒绝 HTTP 状态码

直接用 HTTP 状态码(400/500),是在偷懒

库存不足、余额不足、活动未开始,都是 400? 前端怎么展示?用户怎么理解?

混用状态码,其实就是在逃避定义的责任。

三段式结构

好的错误码,像车牌号,具备定位能力

建议组合:类型 + 服务 + 场景

错误码解析
  • Type(谁的错)

    • A:用户错了(参数填反)。

    • B:系统错了(逻辑校验)。

    • C:第三方错了(依赖挂掉)。

  • Service(哪里的错)01用户中心,02订单中心。

  • Scenario(具体的错)004具体死因。

枚举管理

不要在代码里写死字符串。用枚举(Enum)来管理这些法律条款。

错误码结构

执法:全局捕获

有了法律,还需要执法者。

在 Spring Boot 中,@ControllerAdvice就是那个铁面无私的法官。

分层治理
全局异常捕获流程

处理器的核心逻辑,在于分层。我们要区分可预见和不可预见。

  1. 业务异常(BizException):这是我们主动抛出的。

    • 处理:记录 INFO 日志。

    • 响应:返回对应的业务错误码。

    • 态度:这是用户的问题,与系统无关。

  2. 系统异常(Exception):这是意料之外的 Bug(空指针、SQL 报错)。

    • 处理:记录 ERROR 日志,打印完整堆栈

    • 响应:返回统一的SYSTEM_ERROR,掩盖内部细节。

    • 态度:这是系统的耻辱,必须立刻修复。

@RestControllerAdvice @Slf4j publicclass GlobalExceptionHandler { // 1. 抓业务异常 -> 这种是通知 @ExceptionHandler(BizException.class) public Result<Void> handleBizException(BizException e) { log.info("业务阻断: code={}, msg={}", e.getErrorCode().getCode(), e.getMessage()); return Result.error(e.getErrorCode()); } // 2. 抓系统异常 -> 这种是事故 @ExceptionHandler(Exception.class) public Result<Void> handleException(Exception e) { log.error("系统崩溃", e); // 必须留案底 return Result.error(ErrorCode.SYSTEM_ERROR); // 给用户留面子 } }

进阶:让死因说话

搭建好框架只是及格。优秀的异常处理,能让排查效率提升十倍。

TraceId:案发现场
全链路追踪TraceId

用户报错了,只回一句系统繁忙?开发盲人摸象,病急乱投医。

必须在响应里,带上traceId

public static <T> Result<T> error(ErrorCode errorCode) { // ... result.setTraceId(MDC.get("traceId")); // 留下线索 return result; }

前端截图,后端搜 ID。秒级还原案发现场。

差异化报警

不是什么报错都得报警。

差异化报警策略
  • 业务异常:不报。密码输错三次,是用户的事,不是系统的事。

  • 系统异常:必报。数据库挂了,半夜也得爬起来,这是命。

写在最后

异常处理的本质,是治理不确定性

跑通逻辑,是及格。 兜住意外,是本事。

衡量系统的标准,不是顺境时的速度,是逆境时的生存能力

把混乱锁在黑盒里,把确定性交付给世界。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 16:58:47

ESP8266/ESP32异步OTA更新神器:AsyncElegantOTA深度解析

ESP8266/ESP32异步OTA更新神器&#xff1a;AsyncElegantOTA深度解析 【免费下载链接】AsyncElegantOTA Deprecated: Perform OTAs for ESP8266 / ESP32 Elegantly! Uses AsyncWebServer 项目地址: https://gitcode.com/gh_mirrors/as/AsyncElegantOTA 在物联网设备快速发…

作者头像 李华
网站建设 2026/6/10 16:57:08

通达信买卖点副图

{}F:100*(C-REF(C,1))/REF(C,1); 今小昨:IF(C<REF(O,1) AND F<0,1,0); S1:今小昨; 今小前:IF(C<REF(O,2) AND F<0,1,0),LINETHICK0; S2:今小前; A1:S10 AND REF(S1,1)1 AND S20 AND REF(S2,1)1 AND CROSS(ZIG(3,3) ,REF(ZIG(3 ,3),1)); A2:S10 AND REF(S1,1)1 AND …

作者头像 李华
网站建设 2026/6/9 17:50:29

三全项背离副图 源码 背离

{}低位金叉:CROSS(DIFF,DEA) AND DIFF<-0.1; STICKLINE(低位金叉,0,0.03,6,0),COLORYELLOW; DRAWTEXT(低位金叉,0.05, 低位金叉),COLORWHITE; JCCOUNT:COUNT(CROSS(DIFF,DEA),BARSLAST(DEA>0)); 二次金叉:CROSS(DIFF,DEA) AND DEA<0 AND COUNT(JCCOUNT2,21)1; STICKLI…

作者头像 李华
网站建设 2026/6/10 17:29:32

5分钟快速上手:Masa模组汉化包让你的Minecraft 1.21完全中文化

5分钟快速上手&#xff1a;Masa模组汉化包让你的Minecraft 1.21完全中文化 【免费下载链接】masa-mods-chinese 一个masa mods的汉化资源包 项目地址: https://gitcode.com/gh_mirrors/ma/masa-mods-chinese 还在为Masa模组的英文界面而头疼吗&#xff1f;每次打开配置界…

作者头像 李华
网站建设 2026/6/10 15:06:35

【电力系统】考虑源荷不平衡的微电网鲁棒定价研究附matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码获取及仿…

作者头像 李华
网站建设 2026/6/10 0:23:22

统计代码行数

在项目的 src 目录下&#xff0c;我们只需要在该目录下运行 PowerShell 工具&#xff0c;打开命令行窗口&#xff0c;输入以下命令&#xff1a; (Get-ChildItem -Recurse -File | Get-Content | Measure-Object).Count参考&#xff1a; 前端项目中统计代码行数的6种方式

作者头像 李华