异常处理实践 - 抛异常+错误码

创建一个业务异常基类 BaseException extends RuntimeException ,为其添加两个属性:code 和 message ,并添加一些常用的构造方法。

创建一个业务异常基类 BaseException extends RuntimeException ,为其添加两个属性:code 和 message ,并添加一些常用的构造方法。

哈喽,大家好,我是指北君。

今天和大家分享一下异常处理和错误码管理。

前言

在业务逻辑中,通常使用两种方式处理异常:

  • 返回错误码:优点是性能更好,但是不宜维护。
  • 抛出异常:可以使得代码更清晰,可读性更好,更符合面向对象。

选择哪种需要根据场景而定,不管如何选择,只要团队达成共识,统一规范就可以。

下面介绍一下我使用的处理异常的方式。

自定义异常

创建一个业务异常基类 BaseException extends RuntimeException ,为其添加两个属性:code 和 message ,并添加一些常用的构造方法。

其中,code的作用是储存错误码,在返回前台时将错误码返回给用户。

图片

抛出异常:

图片

错误码管理

上面的自定义异常看起来很简单,但是不够优雅和简单。怎么将错误码和错误信息管理起来,是我们接下来要解决的问题。

我使用了 Enum ,先创建一个接口,其中包含两个方法:

  • toCode():将枚举值转为 int 错误码,默认已实现;
  • getMsg():获取枚举中的异常信息。

图片

下面创建一个枚举类,实现上面的接口:

图片

观察上面的错误码枚举类,我们发现,枚举值为字母+错误码,属性msg为错误信息。

这样将错误码和异常信息统一管理起来之后,抛出异常的代码就可优化为:

图片

然而这样依然不够优雅,代码量比之前还要长。要是能够只传枚举值一个参数就好了,那么我们继续优化。

创建一个异常类 BusinessException extends BaseException (创建一个子类,用来接收枚举值),如下:

图片

这样我们就可以优雅的抛出 BusinessException 了:

图片

如果想要保留原异常信息,还可以使用:

图片

以上就是对异常处理的封装,使用时,只需要在每个业务模块中新建一个异常枚举类,用来统一管理异常;需要时,在代码中抛出 BusinessException 即可。

统一异常处理

最后,我们再使用 @ControllerAdvice 和 @ExceptionHandler 注解做一下统一异常处理,它的作用是:

  • 将业务异常打印到日志中
  • 将系统异常封装为 BaseException 进行返回,同样打印日志;
  • 这里也可以做其他操作,比如短信提醒等。

代码如下:

图片

图片

©本文为清一色官方代发,观点仅代表作者本人,与清一色无关。清一色对文中陈述、观点判断保持中立,不对所包含内容的准确性、可靠性或完整性提供任何明示或暗示的保证。本文不作为投资理财建议,请读者仅作参考,并请自行承担全部责任。文中部分文字/图片/视频/音频等来源于网络,如侵犯到著作权人的权利,请与我们联系(微信/QQ:1074760229)。转载请注明出处:清一色财经

(0)
打赏 微信扫码打赏 微信扫码打赏 支付宝扫码打赏 支付宝扫码打赏
清一色的头像清一色管理团队
上一篇 2023年5月6日 19:22
下一篇 2023年5月6日 19:22

相关推荐

发表评论

登录后才能评论

联系我们

在线咨询:1643011589-QQbutton

手机:13798586780

QQ/微信:1074760229

QQ群:551893940

工作时间:工作日9:00-18:00,节假日休息

关注微信