从UndeclaredThrowableException中获取到需要的异常信息

在接口B中调用了接口A中的方法,由于数据库数据的问题导致空指针异常,而发生异常的地方并未在接口A中try catch块中.
此时在接口B中写常规的try catch语句:

try{
......
}catch(e:Exception){
 log.message = e.message
}

运行代码后查看记录发现log中并没有记录错误信息message
于是打断点去查看catch到的异常,发现是一堆奇怪的东西…
从UndeclaredThrowableException中获取到需要的异常信息_第1张图片而 detailMessage 的值为null,难怪没有message的内容.
点开发现undeclaredThrowable是一个java.lang.reflect.UndeclaredThrowableException类型的异常,
而在它里面有一个叫做target的是一个java.lang.reflect.InvocationTargetException类型的异常,真正的错误信息在target里面的detailMessage中.
百度了一下这两个异常,原理这里不再粘贴,解决标题所示问题的方法如下:
将catch到的e强转成UndeclaredThrowable,再获取到它下面的target强转成InvocationTargetException,由于这个异常中没有重写getMessage方法,所以需要先调用getTargetException方法再调用getMessage.
如此则能获取到我们需要的错误信息了.
由于代码中catch处较多,我写了一个方法来获取message并对异常类型做简单处理.
语言为kotlin,此处原理相同,Java写法大同小异就不再补充.

private fun getMessageFromException(e:Exception):String?{
    var message:String?=null
    if (e is UndeclaredThrowableException){
      val target = e.undeclaredThrowable as InvocationTargetException
      message = target.targetException.message
    }
    else
      message = e.message
    return message
  }

完.

你可能感兴趣的:(从UndeclaredThrowableException中获取到需要的异常信息)