谷歌官方提供了apktool可以逆向已經發布出去的APK應用,即反編譯已經打包成功的APK文件,使用它可以將其反編譯成非常接近打包前的原始格式,對于APK來說,可以具體的逆向AndroidManifest.xml、資源文件resources.arsc以及將dex文件反編譯成可以調試的smali文件。
Warnning
但apktool并不等于是可以用來侵犯前作者的作品的工具,所以使用apktool工具的用戶千萬不用用其來進行不正當、非法的使用。
It is NOT intended for piracy and other non-legal uses. It could be used for localizing, adding some features or support for custom platforms and other GOOD purposes. Just try to be fair with authors of an app, that you use and probably like.
關于apktool
1、反編譯資源文件到原始格式(including resources.arsc, XMLs and 9.png files)并且重建他們;
2、smali debugging: SmaliDebugging已經不支持了,猜測可能另一類的dex2jar工具崛起太快,已經可以將dex文件直接反編譯成jar了;
3、更多關于apktool。
使用apktool
walfred覺得apktool目前最大的作用是可以逆向AndroidManifest.xml、資源文件resources.arsc,這里就簡單的使用apktool來逆向一簡單的hello程序吧。
如果已經有了Android開發環境就能很快使用上apktool了,這里假設你已經可以直接使用apktool了。
反編譯decode
這時我們可以看到在當前目錄下已經生成HelloOurAndroid/文件夾了,我們來查看下反編譯后的AndroidManifest.xml文件和strings.xml文件:
AndroidManifest.xml文件反編譯之后和工程下的時候幾乎是一模一樣,所以我們可以來check下該Android應用的所有權限。
同樣可以查看這些hardcode的內容:
rebuild重打包
重打包剛剛修改過的HelloOurAndroid.apk,我們就修改strings.xml目錄下的“hello”為:Hello,OurUnix!
然后使用apktoo重新打包,命令如下:
最后將重新編譯之后的APK進行簽名就可以運行了,當然如果你不想這么麻煩的去解包看,aapt這個工具也可以做到類似的功能哦,但最大的特點是aapt不需要解包。
新聞熱點
疑難解答
圖片精選