一、问题说明
1. 不嵌套的情形,比较简单,直接调e.getMessage()就行
2. 嵌套的情形,如果用到后台框架的话,抛出的异常可能嵌套不止一层,这个数量没办法确定
先从简单的开始,弄嵌套两层的吧
二、解决问题
通过上面的简单分析,我们可以写一个简单的工具方法,来不断去除嵌套Exception的外层包装,拿到最里面真实的异常信息
代码如下:
public class ExceptionUtil {
// 获取嵌套异常中的最终信息
public static String getRealMessage(Throwable e) {
// 如果e不为空,则去掉外层的异常包装
while (e != null) {
Throwable cause = e.getCause();
if (cause == null) {
return e.getMessage();
}
e = cause;
}
return "";
}
}
调用(以前面的嵌套情形为例,当然不带嵌套的也适用):
public static void main(String[] args) {
try {
test2();
} catch (Exception e) {
System.out.println(ExceptionUtil.getRealMessage(e));
}
}
相关参考:
写这个参考了mybatis3.5.1的ExceptionUtil中的unwrapThrowable方法,另外还参考了https://blog.csdn.net/Dax1n/article/details/88872355
附问题说明中的代码:
不嵌套的情形
public static void main(String[] args) {
test1();
}
public static void test1() {
try {
int a = 1/0;
} catch (Exception e) {
System.out.println(e.getMessage());
}
}
嵌套的情形:
public static void main(String[] args) {
try {
test2();
} catch (Exception e) {
System.out.println(e.getMessage());
}
}
public static void test1() {
try {
int a = 1/0;
} catch (Exception e) {
throw new RuntimeException(new IllegalArgumentException(e));
}
}