反編譯之將脫殼後的dex文件從新打包成apk

前言:經過上一篇文章反編譯之脫去樂固加固的殼,已經能夠拿到dex文件了,那麼咱們怎麼將dex文件從新打包回新的apk呢?若是有這樣的疑問,就看看這篇文章吧!必定會幫到你的!html

獲得dex文件以後該作什麼?

  說實話在我剛獲得脫殼後的dex的文件的時候,有點懵,我在想拿到這個dex文件以後該作什麼呢?怎麼將這個真正的dex文件從新打包回apk呢?咱們都知道沒有加固的app反編譯以後,源碼是smali文件,但如今我拿到的是dex文件,因此在拿到dex文件以後,咱們要作的就是將dex文件編譯成smali文件,而後從新編譯成apk。java

將dex文件編譯成smali文件

  將dex文件編譯成smali文件,咱們須要下載baksmali.jar文件,下載baksmali.jar文件以後,就能夠經過如下命令將dex文件編譯成smali文件了:android

java -jar baksmali.jar smaliTest.dex
複製代碼

如:你要編譯的dex文件是testSmali.dex則輸入的命令是sass

java -jar basksmali.jar testSmali.dex
複製代碼

若是編譯成功,此時會生成一個out目錄,out目錄裏面的文件就是smali文件了。有時可能會遇到下面的錯誤bash

Exception in thread "main"app

com.beust.jcommander.MissingCommandException: Expected a command, got classes.dexatui

com.beust.jcommander.JCommander.parseValues(JCommander.java:725)atspa

com.beust.jcommander.JCommander.parse(JCommander.java:304)atcode

com.beust.jcommander.JCommander.parse(JCommander.java:287)at org.jf.baksmali.Main.main(Main.java:90)cdn

這時你只要將上面的命令換成

java -jar basksmali.jar disassemble testSmali.dex
複製代碼

便可解決。

回編譯的注意事項

  回編譯通過加固後的app,還須要修改AndroidManifest.xml文件,具體的修改內容以下

須要將android:name="xxx"裏面"xxx"的內容換成android:value="yyy"裏面的"yyy",同時須要刪除那行。

  可能一個apk會有幾個dex文件,在將dex文件編譯成smali文件時會有好幾個文件夾,這時咱們要按下圖來命名smali文件夾

好了,下面你就能夠用apktool b xxx來打包通過你脫殼後的apk了。

注意:這時猴的apk還不能直接安裝哦,還須要進行簽名,而後才能安裝。

結束語

  這篇文章有點短,其實將dex文件編譯成smali文件原本就不復雜,這篇文章的主要目的是告訴在得到dex文件後,怎樣將dex文件塞回去,從新打包生成新的apk,在這個過程當中若是有什麼問題,歡迎在下面留言討論。

  轉載請註明出處:www.wizardev.cn

歡迎關注個人公衆號
掃碼關注公衆號,回覆「獲取資料」有驚喜
相關文章
相關標籤/搜索