背景:

项目运行过程中会出现各种各样的问题,常见的有以下几种情况:

  1. 业务流程分析疏漏,对业务流程的反向操作、边界分析设计不充分

  2. 调用外部服务、调用外部系统出现的超时、错误、返回值与预期不符

  3. 外部资源连通性问题,db等服务器出现的网络抖动或宕机

无论是分析设计、开发、测试、线上都需要能够准确定位问题并制定解决方案。

目的:

  • 规范化异常的处理过程,避免异常被吞和到处都在捕获异常的情况

  • 准确的反馈异常信息,为定位问题提供依据

  • 通用性异常全局处理,降低业务开发关注度

  • 对异常情况进行预警,以便能够及时响应

一、异常规划

1. 业务类异常

造成业务流程不能正确执行的行为,常见的几种:

  • 输入必填验证

  • 业务状态约束校验

  • 权限验证

  • 调用外部服务返回数据不符合预期

这类异常需要给调用方返回明确的异常描述信息,一般情况下和代码无关,无需调整编码

注:是业务完整性的一部分,需提前分析

2. 系统类异常

  • 服务调用异常: 超时、中断、接口异常(非200请求)

  • 第三方异常 :db\redis\消息队列 连接失败等

注:通常与业务流程无关,与第三方系统有关,不能简单的通过调整代码解决

3. 通用异常

编码不严谨、数据异常造成的问题,不可预测

举例:参数类型不匹配、空指针、数组越界

二、异常拦截

在springboot中全局异常拦截处理已知的有下面2种方案:

方案1:@ControllerAdvice、实现ErrorController

注:利用springboot自带的拦截机制,只需要定义出处理的策略,没有破坏springboot的约定

方案2:继承AbstractHandlerExceptionResolver,完全自定义处理策略

注:使用spring中最底层的类,打破了springboot的约定,能够拦截到所有异常

三、方案实践

笔者基于方案一进行实践。

1. 异常拦截时序图

2. RrcRestAdvice实现代码

2. RrcExpHandler实现代码

注意:基于RestControllerAdvice的异常拦截只能捕获请求达controller之后的程序异常,所以需要实现ErrorController处理之前的异常。

总结:

推荐基于springboot中@ControllerAdvice 和 ErrorController接口的约定,相对较符合springboot的约定。

其他可选方案:

继承AbstractHandlerExceptionResolver

优点:可完全自定义处理策略。缺点:对框架约定破坏较为严重,自定义处理策略容易疏漏。

继承HandlerInterceptorAdapter

理论上可以处理业务代码抛出的异常,优缺点没有进行过验证。

Springboot项目中异常拦截设计与处理的更多相关文章

  1. springboot(五).如何在springboot项目中使用拦截器

    在每个项目中,拦截器都是我们经常会去使用的东西,基本上任一一个项目都缺不了拦截器的使用. 如日志记录.登录验证,session验证等,都需要拦截器来拦截URL请求,那springboot中的拦截器是如 ...

  2. 如何在SpringBoot项目中使用拦截器

    相比springmvc,springboot中拦截器不需要在xml中配置,只需定义拦截器类 implements HandlerInterceptor 和拦截器拦截路径的配置类extends WebM ...

  3. SpringBoot项目中,异常拦截

    SpringBoot自带异常拦截@ControllerAdvice 1.创建一个SellerExceptionHandler类打上@ControllerAdvice标签 @ControllerAdvi ...

  4. SpringBoot项目中遇到的BUG

    1.启动项目的时候报错 1.Error starting ApplicationContext. To display the auto-configuration report re-run you ...

  5. springboot项目中接口入参的简单校验

    .katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > ...

  6. Spring-Boot项目中配置redis注解缓存

    Spring-Boot项目中配置redis注解缓存 在pom中添加redis缓存支持依赖 <dependency> <groupId>org.springframework.b ...

  7. SpringBoot12 QueryDSL01之QueryDSL介绍、springBoot项目中集成QueryDSL

    1 QueryDSL介绍 1.1 背景 QueryDSL的诞生解决了HQL查询类型安全方面的缺陷:HQL查询的扩展需要用字符串拼接的方式进行,这往往会导致代码的阅读困难:通过字符串对域类型和属性的不安 ...

  8. 在SpringBoot项目中添加logback的MDC

    在SpringBoot项目中添加logback的MDC     先看下MDC是什么 Mapped Diagnostic Context,用于打LOG时跟踪一个“会话“.一个”事务“.举例,有一个web ...

  9. 自身使用的springboot项目中比较全的pom.xml

    在学习的时候常建新的项目,mark下商用的jar <dependency> <groupId>org.mybatis</groupId> <artifactI ...

随机推荐

  1. 项目Alpha冲刺--6/10

    项目Alpha冲刺--6/10 作业要求 这个作业属于哪个课程 软件工程1916-W(福州大学) 这个作业要求在哪里 项目Alpha冲刺 团队名称 基于云的胜利冲锋队 项目名称 云评:高校学生成绩综合 ...

  2. luoguP2768: 珍珠项链(矩阵乘法优化DP)

    题意:有K种珍珠,每种N颗,求长度为1~N的项链,包含K种珍珠的项链种类数.N<=1e9, K<=30; 思路:矩阵快速幂,加个1累加前缀和即可. #include<bits/std ...

  3. 【项目管理工具】—— Microsoft Office Project 介绍

    Project是由微软开发的项目管理软件.设计的目的在于协助项目经理发展计划,为任务分配资源.跟踪计划.管理预算和分析工作量. 对于我们之前的项目来说,之前的整体计划和WBS任务分解都是通过Excel ...

  4. httpclient post请求中文乱码解决办法

    在使用httpclient发送post请求的时候,接收端中文乱码问题解决. 正文: 我们都知道,一般情况下使用post请求是不会出现中文乱码的.可是在使用httpclient发送post请求报文含中文 ...

  5. ZOJ 2676 Network Wars(网络流+分数规划)

    传送门 题意:求无向图割集中平均边权最小的集合. 论文<最小割模型在信息学竞赛中的应用>原题. 分数规划.每一条边取上的代价为1. #include <bits/stdc++.h&g ...

  6. 1、HDFS 架构、启动过程

    Hadoop Distributed File System 易于拓展的分布式文件系统 运行在大量普通廉价机器上,提供容错机制 为大量用户提供性能不错的文件存取服务 NameNode Namenode ...

  7. Spring Security 认证执行流程

    本文基于 Spring Security 5.x 推荐阅读: 项目集成Spring Security SpringSecurity 整合 JWT 一.外层-正常登陆调用 项目启动后会自动寻找 User ...

  8. 基于思岚A1激光雷达+OpenGL+VS2017的Ramer-Douglas-Peucker算法的实现

    时隔两年 又借到了之前的那个激光雷达,最老版本的思岚A1,甚至不支持新的固件,并且转接板也不见了,看了下淘宝店卖¥80,但是官方提供了一个基于STM32的实现方式,于是我估摸着这个转接板只是一个普通的 ...

  9. L1434滑雪

    一,看题 1,这个长度怎么算的. 从它自己数,可以走下去的位置. 2,这个题的衣服怎么披上去呀. 3,搜索目标,状态. 肯定要用坐标,不然怎么搜索. 4,在前期还是多写把. 5,我靠这个点还是随机的& ...

  10. Gift to XBACK(小小礼物)

    什么白天 什么黑夜 我没有 准备着给你的 Surprise 你给我的爱 让我觉得已足够 是你让我相信爱会有 是你的爱陪我绕宇宙 打开日记本写下忧愁 你却让我看时间轴 我才知道现在我能看到的画面 拥有你 ...