我们定义的DataNotFoundException的编码为:1001
为什么产生
我们来看看dubbo的源码进行分析,如果Dubbo的 provider端 抛出异常(Throwable),则会被 provider端 的ExceptionFilter拦截到,执行以下invoke方法,里面有个实现****Listener类,重写了onResponse。
我们来分析一些代码
if (appResponse.hasException() && GenericService.class != invoker.getInterface())
上面代码的含义就是 如果有异常并且****未实现GenericService接口,进入后续判断逻辑,否则直接返回结果。
上面代码的含义就是 不是RuntimeException类型的异常,并且是受检异常(继承Exception),直接抛出。
上面代码的含义就是 在方法签名上有声明,直接抛出
上面代码的含义就是 如果异常类和接口类在同一个jar包中,直接抛出。
上面代码的含义就是 以java.或javax.开头的异常直接抛出。
上面代码的含义就是 dubbo自身的异常,直接抛出。
不满足上述条件,会做toString处理并被封装成RuntimeException抛出
现在我们知道了 为什么我们自定义的异常,没有正确的抛出,这个是因为上面的几个条件,我们都没有满足,所以最后dubbo把它封装成了RuntimeException。
如何解决
解决方法就针对上面的几个条件进行,有几种方案,我们一一看一下
**1、**将该异常的包名以java.或者javax. 开头
这个方案不现实,也不符合规范,所以不采用
2、业务****异常继承Exception,变为checked异常
自定义的业务异常本身属于RuntimeException,所以也不采用
**3、**异常类和接口类在同一jar包里
较大的项目一般都会有一些common包,定义好异常类型,使用二方包的方式引用,所以也不适用
**4、**provider的api明确写明throws XxxException
作为生产服务端,不应显式抛出异常给客户的进行处理,所以也不适用
最终方案
以上方案都不合适,我们这里介绍个最终的方案,即采用dubbo的filter重写,dubbo的异常处理。
1、将dubbo源码中ExceptionFilter复制到我们的项目改名为DubboExceptionFilter
修改一些代码
2、在此处加上一段代码来过滤我们项目中的异常,以免被dubbo重新封装
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
帮助,可以添加下面V无偿领取!(备注Android)**
[外链图片转存中…(img-Af4TxgBL-1710935042928)]