最近接手一个新项目,写用例的时候去翻看代码,发现部分代码里缺少基本的异常处理,包括对参数异常以及业务异常的处理。对照之前负责过的异常处理做得比较好的项目,给开发提了几点建议,顺便又去翻看了之前项目的代码,对常用的异常处理方式做了一个梳理。

1 Java 异常分类

Java 把异常当做对象来处理。Throwable 是所有错误或异常的超类。Throwable 类有两个直接子类:Error 类和 Exception 类。

1、Error 是指 java 运行时系统的内部错误和资源耗尽错误,是程序无法处理的异常,应用程序不会抛出该类对象。

2、Exception 是程序本身可以处理的异常,应尽可能去处理这些异常。Exception 分两类,一个是运行时异常 RuntimeException,一个是检查异常 CheckedException。

3、CheckedException 一般是外部错误,这种异常都发生在编译阶段,Java 编译器会强制程序去捕获此类异常。

4、RuntimeException 是那些可能在 Java 虚拟机正常运行期间抛出的异常的超类。这种错误是由程序员引起的错误,可以修正代码解决。

通常在 Controller 层需要去捕获 service 层的异常,防止返回一些不友好的错误信息到客户端,但如果 Controller 层每个方法都用模块化的 try-catch 代码去捕获异常,会很难看也难维护。

异常处理最好是解耦的,并且都放在一个地方集中管理。Spring 能够较好的处理这种问题,核心如下,这里主要关注前两个:

@ExceptionHandler:统一处理某一类异常,从而能够减少代码重复率和复杂度

@ControllerAdvice:异常集中处理,更好的使业务逻辑与异常处理剥离开

@ResponseStatus:可以将某种异常映射为 HTTP 状态码

单使用@ExceptionHandler,只能在当前 Controller 中处理异常,与@ControllerAdvice组合使用,则可以实现全局异常处理,不用每个 controller 都配置。

2.1 全局异常处理类

下面通过一个实际项目代码来看一下@ControllerAdvice+@ExceptionHandler的使用。

@ControllerAdvice定义全局异常处理类 GlobalExceptionHandler

@ExceptionHandler声明异常处理方法,使用 value 指定异常类,value = Exception.class 表示处理 Controller 层抛出的 Exception 及其子类的异常,这样 Controller 层代码就不需要进行异常处理了。

GlobalExceptionHandler 类中对多个异常进行了处理,这些异常分两类,一类是自定义异常,如 AuthenticationException、BadRequestException,一类是非自定义异常,如 HttpRequestMethodNotSupportedException、TypeMismatchException 等。

2.2 自定义异常

一般项目中都会有一些业务相关(非 JVM 抛出)的异常,可以使用自定义异常继承相关的异常来抛出有用的异常信息,其类名要能体现具体的异常信息,这样根据异常名就可以知道哪里有异常,根据异常提示信息进行程序修改。比如空指针异常 NullPointException,可以抛出 message 为 “xxx 为空” 定位异常位置,而不用输出堆栈信息。

自定义异常通常是定义一个继承自 Exception 类的子类,一般会直接继承自 Exception 类,而不会继承某个运行时的异常类。

下面是项目代码中自定义异常的使用。

定义自定义异常类 AuthenticationException,继承 Exception 类:

在 Service 层抛出 AuthenticationException:

2.3 数据校验异常处理

代码中可以使用@RequestBody+@Valid进行数据绑定和数据校验。

下面是项目代码中对 Post 请求表单的处理,通过@RequestBody将请求 body 中的 json 与表单对象(CreateOrderRequestVO)绑定,使用@Valid进行表单验证。如果不使用@Valid,CreateOrderRequestVO 中的@NotNull等注解不生效。

在表单对象 CreateOrderRequestVO 类的相应字段上添加用于充当校验条件的注解(@NotNull、@NotBlank、@Min等)。

数据校验失败时,Spring MVC 框架会抛出 MethodArgumentNotValidException 异常, 在 GlobalExceptionHandler 中加上对 MethodArgumentNotValidException 异常的声明和处理,就可以全局处理数据校验的异常了。

小结

本文主要是基于项目代码,对其中的全局统一异常处理做了一个梳理和总结。这种异常处理方式将异常处理从业务代码中解耦出来,实现异常信息的统一处理和维护,减少了模板代码,改善了代码的风格。

在日常测试中,有意识地多学习一些开发代码中写得好的地方,为自己以后写代码不断积累经验,还可以适时地对开发的代码提出一些建议。

java异常统一处理_Java 代码中的全局异常处理相关推荐

  1. java项目 异常如何解决_Java项目中常见的异常处理

    发生异常的情况有很多,其中包括以下几大类: 1. 空指针异常: 2. 用户输入异常: 3. 多层异常捕获: 想要知道Java是如何处理异常的,就需要掌握以下这三种异常的处理: 1.检查性异常:最具代表 ...

  2. java 不要使用魔法值_Java代码中的魔法值

    所谓魔法值,是指在代码中直接出现的数值,只有在这个数值记述的那部分代码中才能明确了解其含义. 1. 前言 重构老代码中遇到了不少类似下面这种写法: public void attend(String ...

  3. java程序优化快捷键_Java 代码中针对性能优化的总结方案

    在一个好的项目中代码优化是永远离不开的话题,如果有充足的时间开发和维护代码,必须考虑每个可以优化的细节,日积月累,项目的质量才会上升,代码优化是绝对有必要的工作.代码优化的主要目的是减少代码块,提升代 ...

  4. java元素符号是什么_Java 代码中 @ 符号是什么意思?

    展开全部 annotation. Annotation,是Java5的新特性,下面是Sun的Tutorial的描述,因为是英文,这里我翻译下,希望能够比较清晰323131333532363134313 ...

  5. java ip 白名单_Java代码中对IP进行白名单验证

    public classipUtil {//IP的正则,这个正则不能验证第一组数字为0的情况//private static Pattern pattern = Pattern//.compile(& ...

  6. java异常对象引用变量_Java面向对象编程-异常处理

    第九章 异常处理 异常情况会改变正常的流程,导致恶劣的后果,为了减少损失,应该事先充分预料所有可能出现的异常,然后采取以下措施: 首先考虑避免异常,彻底杜绝异常的发生:如果不能完全避免,则尽可能地减少 ...

  7. java 异常面试问题_Java异常面试问答

    java 异常面试问题 Java provides a robust and object-oriented approach to handle exception scenarios known ...

  8. SpringBoot - 统一格式封装及高阶全局异常处理

    文章目录 Pre 演进过程 版本V1 版本2 Step1 约定统一返回格式 Step2 开发统一返回对象 Step3 约定接口状态码 Step4 验证 Step5 完善全局异常处理 @RestCont ...

  9. 【学习笔记】springboot中的全局异常处理 和@ControllerAdvice的使用

    文章目录 全局异常处理 例子 @ControllerAdvice的其他使用场景 全局异常处理 系统中异常包括:编译时异常和运行时异常RuntimeException ,前者通过捕获异常从而获取异常信息 ...

最新文章

  1. 深蓝学院的深度学习理论与实践课程:第五章
  2. python实现数据库连接池_Python实现Mysql数据库连接池
  3. CentOS7 Tomcat安装
  4. msiexec 命令使用文档
  5. 数据库的关系运算和完整性约束
  6. html字符串长度函数,最常用的20个javascript方法函数
  7. mysql中的group_MySQL中使用group
  8. SpringBoot常用注解说明
  9. MySQL深入02-DML之Select查询
  10. GitHub Universe 2020 强势登陆,GitCode直播已上线
  11. apache31分是重症吗,APACHEⅢ重症评估系统
  12. webpack之loader篇
  13. 啊哈算法之炸弹人(广度优先搜索)
  14. 系统分析和设计方法之系统分析
  15. 小米Max详细刷成开发版开启Root超级权限的经验
  16. 2021年,我们还需要入门深度学习吗?
  17. 阿里巴巴淘系技术部拍卖部-春招提前批
  18. lazada代运营-代运营服务平台
  19. iTOP-3588开发板Android 固件编译
  20. Qt动画之仿Win8 Metro主界面

热门文章

  1. android开发ssh框架搭建,基于SSH框架的Android系统的研究
  2. ABAP总结-转载,好全啊
  3. 2022-2028全球飞机拖船和牵引车以及货物和行李处理设备行业调研及趋势分析报告
  4. 双目测距代码 python opencv 利用双目摄像头拍照,测距
  5. 基于JSP的人力资源管理系统
  6. 一炉真香起 静中开鸿蒙是谁写的,430章香海香消玉殒
  7. 软件测试用例的设计以及分类
  8. springcloud 学习项目
  9. c语言choose函数怎么用,谁说CHOOSE函数简单?这8种用法,赌1毛钱你不会!
  10. 取证导论 Volatility入门使用——ctf公开课笔记记录