全局处理我们可以采用Spring的ExceptionHandler,通过字面简单理解就是异常事件捕获,那实际上用起来也比较简单方便。
我们开发程序异常处理是不可避免地,实际上java 对于运行时异常的打印信息已经足够详细,但是对于前后端分离或者代码规范的严格要求的项目,进行统一的异常封装是非常有必要的,这样前端可以直接通过状态码和错误消息获取到不同类型的异常,也可以不做处理直接展示。
其实还是通过AOP的思想来进行异常捕获,这个我没有深入研究源码,所以没法展开来说。
简单看下这个注解
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface ExceptionHandler {
Class<? extends Throwable>[] value() default {};
}
只有一个参数,要求我们传入一个实现了Throwable接口的类对象,也就是说,无论是很大的Exception.class、RuntimeException.class,还是自定义的各种异常,都是可以捕获到的
@RestControllerAdvice
@Slf4j
public class GlobalExceptionHandler {
@ExceptionHandler(value = RuntimeException.class)
public R AllExpection(RuntimeException e){
log.error("日志错误信息:", e);
String msg = "运行时异常:" + e.getMessage();
return R.fail(500, msg);
}
}
这里我用了一个@RestControllerAdvice注解,是为了加载这个GlobalExceptionHandler 类,其实可以有很多个这种ExceptionHandler类,用于处理各种不同的异常,同样也可以一个类里面很多方法,看实际业务场景就好
然后就是@ExceptionHandler(value = RuntimeException.class),我们这个就捕获一下RuntimeException异常,拿到了之后封装到R类返回给前端,因为前端正常接收数据也是R类型,所以无需额外处理,所有请求都是一样的格式。
可能还需要注意一下log.error,实际上如果我们用@ExceptionHandler注解捕获了异常,那控制台就不会输出对应的异常信息和堆栈信息了,这样我们通过控制台日志查找分析异常就会很困难,这时就可以使用log.error把异常信息打印到日志里,全局异常处理就完成了。
写一个小小的公共类,前端后端都方便。
|