在jadx出现之前,我一般是使用apktool和dex2jar这两个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加入到环境变量。
直接下载安装
- github: https://github.com/skylot/jadx/releases
- sourceforge: http://sourceforge.net/projects/jadx/files/
使用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"