有时会需要反编译APK,各人有各人的原因,你都懂的……
准备工作:
下载APKTool,通过下面这个连接进行下载,
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
)
执行完上面语句后,如果没有出现错误提示,则成功反编译了,找到foldername目录,打开smali目录即为反编译出来的字节。
但我在执行上面语句后,却出现了错误提示:
- 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
好啦,到此就成功打包了一个新的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执行文件。
大功告成!!!
参考文章:
- brut.androlib.err.UndefinedResObject: resource spec:
- 0x010300dd