做java开发的时候,经常会遇到代码抛异常后,需要把异常信息保存到数据库或者上传到云服务器做cache分析。这时候就需要获取异常的堆栈信息(详细错误信息)。
用e.getMessage()来获取到的异常信息内容并不全,而且有时候为空。我们可以用下面方法来获取。
public class Test {
/**
* 获取详细日志
* @param throwable
* @return
*/
public static String getStackTrace(Throwable throwable){
StringWriter sw = new StringWriter();
PrintWriter pw = new PrintWriter(sw);
String errMsg = null;
try {
throwable.printStackTrace(pw);
errMsg = sw.toString();
} catch (Exception e) {
}finally{
pw.close();
}
return errMsg;
}
public static void main(String[] args) {
try
{
int i = 0;
int m = 10 / i;
} catch (Exception e)
{
System.out.println(e.getMessage());
System.out.println("------------");
System.out.println(Test.getStackTrace(e));
}
}
}
结果:
/ by zero
------------
java.lang.ArithmeticException: / by zero
at Test.main(Test.java:30)