总结网上分散的反编译方法,归类并亲测有效,其完整步骤如下:
一、资源反编译(推荐工具apktool)
1. 下载apktool.jar以及相关文件:
http://code.google.com/p/android-apktool/downloads/list 下载apktool1.4.3.bz2 和apktool-install-linux-r04-brut1.zip。
2. 解压缩以上两个文件,分别得到apktool.jar和apktool-install-linux-r04-brut1文件夹。然后复制apktool.jar到
apktool-install-linux-r04-brut1文件夹中。
3. 进入apktool-install-linux-r04-brut1目录,安装framework(如果要反编译各厂商手机自带的mms,phone之类的apk,因
为它们极大的依赖定制过的framework,所以需要此步骤。)
./apktool if com.htc.resources.apk(以htc为例)
4. 反编译资源:
./apktool d ***.apk(如HtcContacts.apk)
二、代码反编译
经过odex化的apk,按如下步骤反编译;没有odex化的apk,直接跳至第3步(使用apk包中的classes.dex)。
1. odex转smali
http://code.google.com/p/smali/downloads/list 下载四个文件:baksmali-1.4.0.jar 、baksmali 、 smali-1.4.0.jar 、 smali,
放在同一个文件夹(我命名为odex-smali-dex)内。
举例要对Mms.odex进行反编译,需将/system/framework里面的 android.policy.odex, bouncycastle.odex,core.odex,
core-junit.odex, ext.odex,framework.odex,services.odex和Mms.odex文件一同放入odex-smali-dex文件夹内。
进入odex-smali-dex,输入命令: java -jar baksmali-1.4.0.jar -a 10 -x Mms.odex -o Mms_out 得到smali文件。
“ -a 10 ”代表api-level,即android版本号对应的级别。 -o 后为输出目录(默认名为out,里面的文件以.smali结尾)。
2. smali转dex
java -jar smali-1.4.0.jar Mms_out/ -o dex_out/Mms.dex 得到dex文件(Mms.dex)。
3. dex转jar
http://code.google.com/p/dex2jar/downloads/list 下载dex2jar-0.0.9.9.tar.gz,并解压,将dex文件拷到解压路径。
进入解压目录,输入命令: ./d2j-dex2jar.sh Mms.dex 得到jar文件(Mms-dex2jar.jar)。
4.运行jd-gui,打开Mms-dex2jar.jar。
下载jd-gui-0.3.3.linux.i686.tar,解压即可运行。