一直比較喜歡反編譯之類的操作,沒有不尊重原創(chuàng)的意思.就是感覺好玩,或者向別人說的想看下別人怎么實現(xiàn)的.
對于android反編譯重要的是這么兩步,java代碼的反編譯,資源文件的反編譯.這個由apk的解壓結(jié)果可以看出來.
由這個結(jié)論也就引出了反編譯所需要的工具, dex2jar和apktool
java代碼的處理
得到jar文件
解壓的內(nèi)容有個classes.dex文件.
- dex文件是android平臺上的可執(zhí)行文件.這個里面就是處理后的java代碼.
- 所以想要看到java代碼只要對這個文件處理可以了
- 所需要的工具就是dex2jar
使用方法就是命令行輸入 d2j-dex2jar dex文件
需要注意的是你的電腦系統(tǒng)window的執(zhí)行 d2j-dex2jar.bat
mac 的執(zhí)行 d2j-dexjar.sh
因此這里執(zhí)行的命令格式為 sh d2j-dex2ajr.sh dex文件
到這里已經(jīng)得到了jar文件,是不是非常簡單.如果想看jar文件這里就需要另外一個工具了jd-gui可以根據(jù)不同的系統(tǒng)區(qū)下載相應的工具
查看jar文件內(nèi)容
jd-gui 就是查看jar文件的java代碼的可視化工具直接將jar文件
拖進工具就可以看到結(jié)果.
xml文件的處理
上面就已經(jīng)看到了java代碼,另外對于引用的圖片資源,在我們解壓后打開相應的文件夾就可以看到
同樣的方式那么布局文件也是這樣的,有一點不同的是布局文件打開是亂碼的這個時候就需要另外一個工具apktool了
下載apktool
下載apktool后按照說明,將apktool和apktool.jar(window平臺的是apktoo.bat 和apktool.jara)放到同一個文件夾,然后就可以執(zhí)行下面的相關步驟了.
為了方便處理,我將apk文件也放到該目錄下
1.執(zhí)行命令 apktool d release.apk 的到一個編譯后的文件夾結(jié)果
2.打開release 文件夾 進入相關文件夾內(nèi) 再次找到原來亂碼的xml文件打開發(fā)現(xiàn)已經(jīng)看到正常的布局文件了,其他的xml文件也一樣
3.通過這種方式的到的結(jié)果中還有一個smali文件夾,這個里面放的也是處理后的java代碼,smali文件還是有必要學習一下的.
重新打包
如果我們修改了布局之后,如何重新打包呢侠姑?同樣的還是apktool來完成,因為不會修改java代碼所以革命的學習路線還是遙遠的.
通過如下命令
apktool b release -o new_file.apk
可以看到新的apk已經(jīng)得到了,正常情況下現(xiàn)在的這個apk還不能安裝,因為需要重新簽名.
另外在開發(fā)者模式下,通過adb命令可以將目前的這個apk安裝,但是不建議這么區(qū)做.android系統(tǒng)為了安全考慮,規(guī)定每個軟件或者ROM都要簽名,如果沒有簽名系統(tǒng)會認為那對系統(tǒng)有害,無法安裝.
對新文件進行簽名安裝
通過如下格式命令進行簽名
jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore 簽名文件名 -storepass 簽名密碼 待簽名的APK文件名 簽名的別名
線路如圖
相關工具的下載