在jadx出现之前,我一般是使用apktooldex2jar这两个Android反编译工具。这两个工具也有不同的侧重点,如果只是想拿到apk里的一些图片或其他资源或是查看一下布局的layout文件,直接使用apktool -d xxx.apk即可。如果是要查看一下代码实现,就使用d2j-dex2jar.sh反编译一下apk然后使用jd-gui工具查看反编译后的.jar文件。

apktool+dex2jar+jd-gui一直是一个比较流行的Android反编译组合。
在使用过jadx之后觉得jadx相比上面的组合具有如下两个优点:

  • 可以直接反编译出.java文件
  • 查看源码时直接显示资源名称,而不是像jd-gui里显示的资源ID

安装jadx

编译安装

git clone https://github.com/skylot/jadx.git
cd jadx
./gradlew dist

然后将build/jadx/bin加入到环境变量。

直接下载安装

使用jadx

jadx也有GUI,直接双击bin目录下的jadx-gui,然后选择要反编译的apk即可,运行效果如下。
jadx_gui
如果要保存源码,选择File->Save ALL即可保存文件,然后就可以导入Android Studio等IDE中。
我们也可以直接使用命令行反编译apk文件:

jadx -d out classes.dex  #直接输出.java文件到out目录
jadx-gui classes.dex #使用gui打开

在反编译较大的apk时,如果遇到jadx-jui卡顿和假死的情况,可适当优化jvm相关参数,
我直接在~/.bash_profile中加上了如下语句:

export JVM_ARGS="-Xmx4096m -XX:MaxPermSize=1024m"