JAVA语言之小编教您Springboot项目中异常拦截设计与处理
小标 2019-05-09 来源 : 阅读 869 评论 0

摘要:本文主要向大家介绍了JAVA语言之小编教您Springboot项目中异常拦截设计与处理,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

本文主要向大家介绍了JAVA语言之小编教您Springboot项目中异常拦截设计与处理,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

JAVA语言之小编教您Springboot项目中异常拦截设计与处理

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


业务流程分析疏漏,对业务流程的反向操作、边界分析设计不充分
调用外部服务、调用外部系统出现的超时、错误、返回值与预期不符
外部资源连通性问题,db等服务器出现的网络抖动或宕机
无论是分析设计、开发、测试、线上都需要能够准确定位问题并制定解决方案。


目的:


规范化异常的处理过程,避免异常被吞和到处都在捕获异常的情况
准确的反馈异常信息,为定位问题提供依据
通用性异常全局处理,降低业务开发关注度
对异常情况进行预警,以便能够及时响应
一、异常规划


业务类异常


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


输入必填验证
业务状态约束校验
权限验证
调用外部服务返回数据不符合预期
这类异常需要给调用方返回明确的异常描述信息,一般情况下和代码无关,无需调整编码


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


系统类异常


服务调用异常: 超时、中断、接口异常(非200请求)
第三方异常 :db edis消息队列 连接失败等
注:通常与业务流程无关,与第三方系统有关,不能简单的通过调整代码解决


通用异常


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


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


二、异常拦截


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


方案1:@ControllerAdvice、实现ErrorController


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


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


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


三、方案实践


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


异常拦截时序图


RrcRestAdvice实现代码


RrcExpHandler实现代码

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


总结:


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


其他可选方案:


继承AbstractHandlerExceptionResolver


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


继承HandlerInterceptorAdapter


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

   

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注编程语言JAVA频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程