不混淆 >> 源码泄露,相当于开源,而且包体积较大。
混淆 >> 看不懂用户提交的crash信息。
怎么办呢,可以开启混淆,然后让Android Studio打包的时候,导出mapping.txt,这样就可以用SDK自带的工具解读崩溃信息了。
一、正确生成 mapping.txt
app’s gradle
android{ ...
buildTypes {
debug {
buildConfigField "boolean","isDebug","true"
}
release {
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-project.txt'
buildConfigField "boolean","isDebug","false"
}
}
proguard-project.txt
...
-keepattributes LineNumberTable
打包后生成了mapping.txt,但是可能不在apk目录,可以用explorer搜索以下。
实测没有上面两行,打包后也有mapping.txt,不过体积小很多,只有1M不到,似乎只有类名的映射。
二、混淆后的调试法
int Zero=0;
...
void load(){...
if(true) {
savedInstanceState.putInt("test", 1/Zero);
}
如果让用户提交崩溃截图的话。会是这么个玩意:
此界面基于自定义CrashHandler的原理,记录崩溃信息,下次启动时显示。可以看到,Activity的类名都会发生变化,直接看是看不懂的。
若加入 -keepattributes SourceFile 这一混淆规则,上面的信息,每一行会包含原始类名,但行数仍然是混淆后的,需要用mapping.txt去对。
再retrace.bat目录使用命令:
retrace.bat -verbose …\build\outputs\mapping\release\mapping.txt …\release\crash.txt
用SDK自带的 retrace.bat,出来的行数没有变,下载最新版Proguard(https://github.com/Guardsquare/proguard/releases)才成功解析处原始行数。
不敲命令的话也可以直接用Proguard自带的界面程序 proguardgui.bat。
参考: