Android保存App异常信息到本地

本文实例为大家分享了Android保存App异常信息到本地的具体代码,供大家参考,具体内容如下

首先添加权限

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

代码

// 调用该方法造成异常

private void math() {

try {

int a = 0;

int b = 10;

int c = b / a;

} catch (Exception e) {

e.printStackTrace(); // Logcat打印异常

// 保存异常信息

StringWriter sw = new StringWriter();

e.printStackTrace(new PrintWriter(sw, true));

saveException(this, sw.toString());

}

}

/**

* 保存异常信息到本地 Android/data/包名/files/Documents/exception/yyyyMMdd_app_exception.txt

* @param context 上下文

* @param errMsg 异常信息

*/

private void saveException(Context context, String errMsg) {

if (context == null || TextUtils.isEmpty(errMsg)) return;

FileOutputStream fos = null;

try {

// 创建目录

String dirPath = context.getExternalFilesDir(Environment.DIRECTORY_DOCUMENTS).getPath() + "/exception/";

File dir = new File(dirPath);

if (!dir.exists()) {

dir.mkdirs();

}

// 根据当天日期来生成文件名

String date = new SimpleDateFormat("yyyyMMdd", Locale.ENGLISH).format(new Date());

// 创建文件

File file = new File(dirPath, date + "_app_exception.txt");

if (!file.exists()) {

file.createNewFile();

}

fos = new FileOutputStream(file, true);

fos.write(errMsg.getBytes());

fos.write("\n".getBytes());

fos.flush();

} catch (Exception e) {

e.printStackTrace();

} finally {

if (fos != null) {

try {

fos.close();

} catch (Exception e) {

e.printStackTrace();

}

}

}

}

效果如图

可以考虑将当前时间写进文件,更方便排查问题

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是 Android保存App异常信息到本地 的全部内容, 来源链接: utcz.com/p/242923.html

回到顶部