Java 项目中的全局异常处理

全局处理我们可以采用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把异常信息打印到日志里,全局异常处理就完成了。

写一个小小的公共类,前端后端都方便。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值