編輯:關於Android編程
谷歌官方提供了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
復制代碼 代碼如下:
walfred@ubuntu:~/lab/apktool$ apktool d HelloOurAndroid.apk
這時我們可以看到在當前目錄下已經生成HelloOurAndroid/文件夾了,我們來查看下反編譯後的AndroidManifest.xml文件和strings.xml文件:
AndroidManifest.xml文件反編譯之後和工程下的時候幾乎是一模一樣,所以我們可以來check下該Android應用的所有權限。
同樣可以查看這些hardcode的內容:
rebuild重打包
重打包剛剛修改過的HelloOurAndroid.apk,我們就修改strings.xml目錄下的“hello”為:Hello,OurUnix!
然後使用apktoo重新打包,命令如下:
復制代碼 代碼如下:
walfred@ubuntu:~/lab/apktool$ apktool b HelloOurAndroid
最後將重新編譯之後的APK進行簽名就可以運行了,當然如果你不想這麼麻煩的去解包看,aapt這個工具也可以做到類似的功能哦,但最大的特點是aapt不需要解包。
以下分析是基於MTK Android4.4原生的SystemUI與Google 的SystemUI有微小的區別,但兩者的整體框架是差不多的。這一篇是分析SystemUI的
Instant Run官方介紹簡單介紹一下Instant Run,它是Android Studio2.0以後新增的一個運行機制,能夠顯著減少你第二次及以後的構建和部署時間
在android中,經常要用到幫助、about、關於作者等的提示頁面。類似這樣的頁面:這樣的頁面,我們可以通過AlertDialog對話框來設計。設計一個AboutDia
步驟: 1. 下載android 4.4源碼包, 由於GFW原因, 通過谷歌官方網站repo下載源碼比較難, 所以我選擇了國內android