最近追踪一个问题,发现前端没有异常信息,后端也没有异常信息。但是数据就是没有存入数据库。
后来调试发现,是异常信息打印不对。
后端以前的同事直接在事物类上,try{}catch(Expception e){map.put('err',e.getmessage())}了。而前端得到的map中只有err->null。其实这个时候大概可以推断出是空指针异常了。
但是由于没有打印堆栈信息,无法跟踪到是哪一行报空指针异常。因此回忆平时的异常日志都是有caused by。那这个为什么没有caused by?
解决办法1、在trycatch中输出e.printStackTrace();
2、在try catch中throw一个new Exception
如下代码
package com.feu.test;
/**
* 测试异常
*/
public class MyException {
public static void main(String[] args) throws AppException {
MyException myException = new MyException();
myException.entrance(myException);
}
private void entrance(MyException myException) throws AppException {
try {
myException.nullEx();
myException.indexOutEx();
}catch (Exception e){
e.printStackTrace();
throw new AppException(e);
}
}
private void nullEx(){
String ar=null;
if(ar.equals(11)){
}
}
private void indexOutEx(){
String[] arr=new String[1];
String a1 = arr[2];
}
}
自定义异常类
package com.feu.test;
public class AppException extends Exception{
public AppException(Exception e){
super(e);
}
}
当然也可以不用自定义异常类,直接用new Exception(e)
效果如下: