Android 根据mapping文件还原混淆代码
创始人
2024-05-24 05:42:10
0

目录

  • 一、简介
  • 二、还原混淆文件
    • 1、获取mapping.txt混淆文件
    • 2、获取混淆的崩溃堆栈
    • 3、使用工具进行解混淆


一、简介

app发布的时候都会做混淆处理,但是当发生错误的时候,只能看到一些混淆后的代码很难看清楚哪里错了,那么如何将混淆后的代码进行还原呢?

Android sdk 目录下有专门的工具可以帮助我们进行还原。


二、还原混淆文件

1、获取mapping.txt混淆文件

在还原混淆之前,我们需要app的混淆mapping文件,该文件路径:

/app/build/outputs/mapping/release/mapping.txt

混淆文件的格式类似如下:

...
MTT.ThirdAppInfoNew -> a.a:java.lang.String sAppName -> ajava.lang.String sTime -> bjava.lang.String sQua2 -> cjava.lang.String sLc -> djava.lang.String sGuid -> ejava.lang.String sImei -> fjava.lang.String sImsi -> gjava.lang.String sMac -> hlong iPv -> iint iCoreType -> jjava.lang.String sAppVersionName -> kjava.lang.String sAppSignature -> ljava.lang.String sAndroidID -> mlong sWifiConnectedTime -> nint localCoreVersion -> ovoid () -> 
android.arch.core.BuildConfig -> android.arch.core.BuildConfig:boolean DEBUG -> DEBUGjava.lang.String APPLICATION_ID -> APPLICATION_IDjava.lang.String BUILD_TYPE -> BUILD_TYPEjava.lang.String FLAVOR -> FLAVORint VERSION_CODE -> VERSION_CODEjava.lang.String VERSION_NAME -> VERSION_NAME6:6:void () -> 
...

2、获取混淆的崩溃堆栈

混淆的崩溃堆栈如下:

java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String[] java.lang.String.split(java.lang.String)' on a null object reference
at com.cw.tsb.activity.crash.a.a(CrashUtil.java:33)
at com.cw.tsb.activity.crash.JavaCrashActivity.l(JavaCrashActivity.java:100)
at com.cw.tsb.activity.crash.JavaCrashActivity.a(JavaCrashActivity.java:51)
at com.cw.tsb.activity.BaseToolbarButtonActivity$1.onClick(BaseToolbarButtonActivity.java:61)
at android.view.View.performClick(View.java:7664)
at android.view.View.performClickInternal(View.java:7638)
at android.view.View.access$3800(View.java:878)
at android.view.View$PerformClick.run(View.java:29899)
at android.os.Handler.handleCallback(Handler.java:966)
at android.os.Handler.dispatchMessage(Handler.java:110)
at android.os.Looper.loopOnce(Looper.java:205)
at android.os.Looper.loop(Looper.java:293)
at android.app.ActivityThread.main(ActivityThread.java:9596)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:586)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1204)

注:上述堆栈代码第二行中的 a.a 即为混淆代码。

我们将上述堆栈代码保存到 trace.txt 文件中,留作后面解码使用。


3、使用工具进行解混淆

还原混淆工具路径:

../sdk/tools/proguard

首先我们进入到混淆工具的bin目录:

../sdk/tools/proguard/bin

bin 目录(Mac系统)下有 proguard.shproguardgui.shretrace.sh 三个文件。

然后将前面的 mapping.txt(解码文件)trace.txt(混淆堆栈文件) 拷贝到混淆工具的 bin 目录中。

然后在 bin 目录中执行如下命令:

bash retrace.sh -verbose mapping.txt  trace.txt > out.txt

该命令是将混淆的堆栈文件(trace.txt)解码后保存到 out.txt 文件中。

解码后的堆栈如下:

java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String[] java.lang.String.split(java.lang.String)' on a null object reference
at com.cw.tsb.activity.crash.CrashUtil.void crash_nullpoint()(CrashUtil.java:33)
at com.cw.tsb.activity.crash.JavaCrashActivity.void nullPointerException()(JavaCrashActivity.java:100)
at com.cw.tsb.activity.crash.JavaCrashActivity.void onBtnViewClick(int,android.view.View)(JavaCrashActivity.java:51)
at com.cw.tsb.activity.BaseToolbarButtonActivity$1.void onClick(android.view.View)(BaseToolbarButtonActivity.java:61)
at android.view.View.performClick(View.java:7664)
at android.view.View.performClickInternal(View.java:7638)
at android.view.View.access$3800(View.java:878)
at android.view.View$PerformClick.run(View.java:29899)
at android.os.Handler.handleCallback(Handler.java:966)
at android.os.Handler.dispatchMessage(Handler.java:110)
at android.os.Looper.loopOnce(Looper.java:205)
at android.os.Looper.loop(Looper.java:293)
at android.app.ActivityThread.main(ActivityThread.java:9596)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:586)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1204)

其中第二行中的 a.a 被解析成了我们能看懂的源码 void crash_nullpoint()

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...