前面记录了两篇关于如何做混淆的文章,但混淆之后,如果遇到问题,log日志是无法查看的,对应的都是混淆后的类、方法,这时候就需要用retrace.bat指令(retrace.bat|retrace.sh [-verbose] mapping.txt [<stacktrace_file>])将堆栈信息(stacktrace_file)转换成其真实的类、方法名。
堆栈信息如何获取:
方法一:最简单的方法直接copy logcat中的堆栈信息保存为txt
方法二是在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信息:
也可参考:http://blog.youkuaiyun.com/yhqbsand/article/details/39369189