mac下,对apk进行反编译主要是用到apktool和dex2jar两个工具(自行下载),如果只是想拿到apk里的一些图片或其他资源或是layout文件,直接使用apktool -d xxx.apk即可。如果是要查看代码,就使用dex2jar.sh反编译一下apk,然后使用jd-gui工具查看反编译后的.jar文件即可。今天还将介绍一款新的反编译神器:Jadx。
一,apktool的使用
用到的命令: java -jar apktool_2.0.2.jar d androidxxx.apk 其中:androidxxx.apk 要进行反编译的apk包。
1,命令行进入apk文件所在的目录:
|
|
2,执行命令:
|
|
二,反编译java源文件
1,获取classes.dex文件。
这就用到dex2jar和jd-gui了,将androidxx.apk重命名改成androidxx.zip,然后利用解压缩软件解压,得到一个androidxx的目录,我们要拿到里面的classes.dex文件。
2,将classes.dex文件复制到dex2jar-0.0.9.15目录下
|
|
3,执行命令:
|
|
4,用jd-gui工具打开这个jar包就可以看到java源代码了。
三,反编译新工具jadx
在jadx出现之前,一般是使用apktool和dex2jar这两个反编译工具。
1,下载源码或者release包。
skylot/jadx:https://github.com/skylot/jadx/releases
2,使用jadx
jadx也有GUI,直接双击bin目录下的jadx-gui,然后选择要反编译的apk即可。如果要保存源码,选择File->Save ALL即可保存文件,然后就可以导入Android Studio等IDE中。
3,使用命令行反编译apk文件
a,把apk改成zip
b,解压zip获取class.dex文件
c,将class.dex文件放到jadx目录下
进入该目录,执行终端命令:
如果执行命令没有效果,提示commond not found,或者双击打开jadx,说程序来源不明,配置环境变量即可使用,如下:
|
|
//此时编辑.bash_profile文件,加入你的jadx path:
保存修改即可:
然后会提示你选择要反编译的apk,dex文件:
在反编译较大的apk时,如果遇到jadx-jui卡顿和假死的情况,可适当优化jvm相关参数,在~/.bash_profile中加上了如下语句:
|
|
四,总结
apktool+dex2jar+jd-gui一直是一个比较流行的Android反编译方式,jadx相比上面的组合具有如下两个优点:
jadx可以反编译出.java文件
源码直接显示资源名称,而jd-gui里显示的是资源ID。
杜乾,Dusan,Q:291902259
微博:http://weibo.com/u/2876301234
微信公众号:OpenDeveloper
分享不仅限于Android,Web 开发,做开放的完美的开发者。
博客:http://blog.csdn.net/dzsw0117