【Java】获取异常的堆栈信息

【Java】获取异常的堆栈信息

做java开发的时候,经常会遇到代码抛异常后,需要把异常信息保存到数据库或者上传到云服务器做cache分析。这时候就需要获取异常的堆栈信息(详细错误信息)。

有的人用e.getMessage()来获取异常信息,但是这样获取到的信息内容并不全,而且有时候为空。我们可以用下面方法来获取。

package com.bonc.frame.util;

import java.io.PrintWriter;
import java.io.StringWriter;

/**
 * 
 * @author qxl
 * @date 2018年4月11日 上午11:07:52
 * @version 1.0
 */
public class ExceptionUtil {

	public static String getStackTrace(Throwable throwable) {
		StringWriter sw = new StringWriter();
		PrintWriter pw = new PrintWriter(sw);

		try {
			throwable.printStackTrace(pw);
			return sw.toString();
		} finally {
			pw.close();
		}
	}

}

使用也很简单:

	@Test
	public void test4() {
		try {
			int i = 0;
			int m = 10 / i;
		} catch (Exception e) {
			System.out.println(e.getMessage());
			System.out.println("------调皮的分割线------");
			System.out.println(ExceptionUtil.getStackTrace(e));
		}
	}

结果:

【Java】获取异常的堆栈信息_第1张图片

你可能感兴趣的:(java)