在我们开发 app 或者 sdk 的时候,为了安全起见,防止被别人反编译,所以我们都会对我们的代码进行混淆配置。但是混淆之后,利用一些工具,进行 bug 崩溃的采集的时候,那些代码我们看不懂,既然看不懂,还怎么解决bug?不过放心,Android SDK 自带的工具中,有个 proguardgui.bat 可以帮助我们还原代码,我们现在就要简单学习一下,这个工具怎么使用。
一、找到 mapping.txt
我们开启混淆,打正式包后,mapping.txt 文件会在 模块/outputs/mapping/release/mapping.txt 中,例如:
app/outputs/mapping/release/mapping.txt 。所以在这个路径就可以获取到了。如图:
二、使用 proguardgui.bat
1、proguardgui.bat 的位置
proguardgui.bat 存在于,我们 Android SDK 中,例如:Android\Sdk\tools\proguard\bin\proguardgui.bat
如图:
2、点击 proguardgui.bat 就可以打开 proguardgui 页面了
3、点击左侧菜单的 'ReTrace' 按钮
4、点击 'Browse..'按钮,选择 mapping.txt 文件
5、将我们混淆后的异常,复制到输入框中
Caused by: java.lang.ArithmeticException: divide by zero
at j4.b.a(TestUtils.java:1)
at com.young.testdevelopsdk.MainActivity.onCreate(MainActivity.java:8)
at android.app.Activity.performCreate(Activity.java:8000)
at android.app.Activity.performCreate(Activity.java:7984)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:223)
at android.app.ActivityThread.main(ActivityThread.java:7656)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
6、点击右下角的 'ReTrace!' 按钮,进行混淆代码还原
三、提醒
1、要做混淆配置,否则开启了混淆,会最大化优化,只是把代码做替换,基础的混淆配置,在 proguard-rules.pro 文件中加入以下配置:
# 设置混淆的压缩比率 0 ~ 7
-optimizationpasses 5
# 混淆时不使用大小写混合,混淆后的类名为小写
-dontusemixedcaseclassnames
# 指定不去忽略非公共库的类
-dontskipnonpubliclibraryclasses
# 指定不去忽略非公共库的成员
-dontskipnonpubliclibraryclassmembers
# 混淆时不做预校验
-dontpreverify
# 混淆时不记录日志
-verbose
# 代码优化
-dontshrink
# 不优化输入的类文件
-dontoptimize
# 保留注解不混淆
-keepattributes *Annotation*,InnerClasses
# 避免混淆泛型
-keepattributes Signature
# 保留代码行号,方便异常信息的追踪
-keepattributes SourceFile,LineNumberTable
# 混淆采用的算法
-optimizations !code/simplification/cast,!field/*,!class/merging/*