背景:
项目运行过程中会出现各种各样的问题,常见的有以下几种情况:
无论是分析设计、开发、测试、线上都需要能够准确定位问题并制定解决方案。
目的:
一、异常规划
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项目使用拦截器方法详解,包括了Springboot项目使用拦截器方法详解的使用技巧和注意事项,需要的朋友参考一下 1. 创建一个拦截器并实现HandlerInterceptor接口 2. 创建一个配置类MyHandlerInterceptorConfig并继承WebMvcConfigurerAdapter类重写addInterceptors(Interceptor
我有一个rest api: ..... 和serv.prop(请求): 在catch内部,我只想在这个api rest中截获错误类型(400404500502 ecc ecc),并调用记录此错误的外部服务。 谢谢你的帮助
本文向大家介绍springboot全局异常处理详解,包括了springboot全局异常处理详解的使用技巧和注意事项,需要的朋友参考一下 一、单个controller范围的异常处理 说明: 在controller中加入被@ExceptionHandler修饰的类即可(在该注解中指定该方法需要处理的那些异常类) 该异常处理方法只在当前的controller中起作用 二、全部controller范围内起
我试图执行一些适用于代码中所有的通用逻辑。我知道我可以编写一个来拦截快乐路径。但是,我想连接到异常处理生命周期中,以便在呈现错误响应之前执行一些常见的逻辑,比如日志记录。 在Spring Boot/Spring MVC中有这样做的方法吗?如果可能的话,我希望避免为此编写servlet过滤器。
本文向大家介绍SpringBoot使用统一异常处理详解,包括了SpringBoot使用统一异常处理详解的使用技巧和注意事项,需要的朋友参考一下 场景:针对异常处理,我们原来的做法是一般在最外层捕获异常即可,例如在Controller中 这样的话也能解决部分问题,但是无法获取到自己指定的异常,引入全局统一异常处理的话将会极大的改善代码,减少冗余代码的产生。 自定义异常类:注意要继承自RuntimeE
5.1、处理器拦截器简介 Spring Web MVC的处理器拦截器(如无特殊说明,下文所说的拦截器即处理器拦截器) 类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。 5.1.1、常见应用场景 1、日志记录:``记录请求信息的日志,以便进行信息监控、信息统计、计算PV(Page View)等。 2、权限检查:``如登录检测,进入处理器检测检测是否登录,如果没有直接返