关于查看混淆后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输出内容):

182637_bhhH_2363385.png

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

183041_hvyl_2363385.png

也可参考:http://blog.youkuaiyun.com/yhqbsand/article/details/39369189

转载于:https://my.oschina.net/reborn87/blog/602040

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值