关于查看混淆后log查看问题

前面记录了两篇关于如何做混淆的文章,但混淆之后,如果遇到问题,log日志是无法查看的,对应的都是混淆后的类、方法,这时候就需要用retrace.bat指令(retrace.bat|retrace.sh [-verbose] mapping.txt [<stacktrace_file>])将堆栈信息(stacktrace_file)转换成其真实的类、方法名。

堆栈信息如何获取:

  1. 方法一:最简单的方法直接copy logcat中的堆栈信息保存为txt

  2. 方法二是在Application中添加一个异常监听:

Thread.setDefaultUncaughtExceptionHandler(CrashHandler.create(this));

    再在CrashHandler中将堆栈信息保存为文本文件:

LogUtils.e(this, "崩溃toString: " + ex.toString());
StringWriter stringWriter = new StringWriter();
PrintWriter printWriter = new PrintWriter(stringWriter);
printWriter.print(TimeUtils.getCurrentTime());
try {
    dumpPhoneInfo(printWriter);
} catch (NameNotFoundException e) {
    e.printStackTrace();
}
ex.printStackTrace(printWriter);
FileUtils.savaData("error.txt", stringWriter.getBuffer().toString());
printWriter.println();
printWriter.close();
ex.printStackTrace();// 也别忘了同时打印日志信息

这样我们就能够获取到堆栈信息,并保存到了本地。接下来就调用先前所说的指令:

retrace.bat|retrace.sh [-verbose] mapping.txt [<stacktrace_file>

放上几张实例图

(混淆后log输出内容):

关于查看混淆后log查看问题_第1张图片

调用指令,得到真实的log信息:

关于查看混淆后log查看问题_第2张图片

也可参考:http://blog.csdn.net/yhqbsand/article/details/39369189

你可能感兴趣的:(关于查看混淆后log查看问题)