有时会需要反编译APK,各人有各人的原因,你都懂的……
准备工作:
下载APKTool,通过下面这个连接进行下载,https://code.google.com/p/android-apktool/downloads/list
windows下只需要下载这两个文件包即可:apktool1.5.2.tar.bz2和apktool-install-windows-r05-ibot.tar.bz2
分别解压到到一个方便操作的目录下,然后就可以通过控制台进行操作了,当然前提是你配置已经有了JAVA环境,这个网上一搜一大堆,就不赘述了。
反编译:
把要反编译的APK文件放到跟APKTool四个文件的同一个目录下;
打开控制台,跳到该目录(例如是C:\Windows),执行:
cd C:\Windows
然后执行:
apktool d apkname.apk foldername
apkname.apk 表示要进行反编译的APK文件,foldername表示反编译后文件存放的目录,即在当前目录下会自动建一个新目录存放(如:C:\Windows\foldername)
执行完上面语句后,如果没有出现错误提示,则成功反编译了,找到foldername目录,打开smali目录即为反编译出来的字节。
但我在执行上面语句后,却出现了错误提示:
- Exception in thread "main" brut.androlib.err.UndefinedResObject: resource spec:
- 0x010300dd
根据提示描述是找不到资源文件,应该是要反编译的APK文件用到了系统的一些资源。
解决办法:
从手机中导出framework-res.apk文件,该文件是/system/framework下面,把这个文件拷到跟apkTool同一个目录下,执行以下语句把资源文件加进来:
apktool if freagmework-res.apk
执行完以后就可以把framework-res.apk导进来。此时再执行apktool d即可以正常反编译了。
由于反编译出来的是字节码,所以想修改软件逻辑就需要知道一点字节码的知识,可以看这里:寄存器、类型、函数和成员、操作符号。
在这里列举几个常用的逻辑符号的对应smali语法:
符号 smali语法 == if-eq != if-ne equals if-eqz !equals if-nez
修改完代码逻辑后,就要重新打包成APK文件了:
apktool b foldername
其中foldername即放反编译结果的目录,执行成功后会在该目录的dist目录下有一个重新打包后的apk文件。
当然我在重新打包时出现了错误提示:
Exception in thread "main" brut.androlib.AndrolibException: brut.directory.PathN otExist: apktool.yml
从字面上理解就是找不到apktool.yml这个文件,如果在执行apktool d后能正常反编译,在目录中是会存在apktool.yml文件的,我之所以出现这个错误,是因为在反编译时出现了上面提到的“资源找不到”错误后,我看到反编译出了字节码,就没有理会它导致的。
好啦,到此就成功打包了一个新的apk文件了,但还不要高兴得太早,该文件是一个没有签名的apk,有了解过android的应该都知道,没有签名是无法安装的。那就要重新为该文件签一下名了。把你的签名文件和apk拷到同一个目录下,然后执行以后语句即可:
jarsigner -verbose -keystore wendy.keystore -signedjar wendy_signed.apk wendy.apk wendy.keystore
这里输入wendy.keystore即你的签名文件名称,文件wendy.apk,最终生成wendy_signed.apk为Android签名后的APK执行文件。
大功告成!!!
参考文章:
http://blog.creke.net/786.html
http://blog.csdn.net/caszhao/article/details/6030425
http://danqingdani.blog.163.com/blog/static/1860941952012103041246686/
http://blog.csdn.net/wenhaiyan/article/details/5520964
- Exception in thread "main" brut.androlib.err.UndefinedResObject: resource spec:
- 0x010300dd