前言:經過上一篇文章反編譯之脫去樂固加固的殼,已經能夠拿到dex文件了,那麼咱們怎麼將dex文件從新打包回新的apk呢?若是有這樣的疑問,就看看這篇文章吧!必定會幫到你的!html
說實話在我剛獲得脫殼後的dex的文件的時候,有點懵,我在想拿到這個dex文件以後該作什麼呢?怎麼將這個真正的dex文件從新打包回apk呢?咱們都知道沒有加固的app反編譯以後,源碼是smali文件,但如今我拿到的是dex文件,因此在拿到dex文件以後,咱們要作的就是將dex文件編譯成smali文件,而後從新編譯成apk。java
將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