反编译之将脱壳后的dex文件重新打包成apk
前言:通過上一篇文章反編譯之脫去樂固加固的殼,已經可以拿到dex文件了,那么我們怎么將dex文件重新打包回新的apk呢?如果有這樣的疑問,就看看這篇文章吧!一定會幫到你的!
得到dex文件之后該做什么?
??說實話在我剛得到脫殼后的dex的文件的時候,有點懵,我在想拿到這個dex文件之后該做什么呢?怎么將這個真正的dex文件重新打包回apk呢?我們都知道沒有加固的app反編譯之后,源碼是smali文件,但現在我拿到的是dex文件,所以在拿到dex文件之后,我們要做的就是將dex文件編譯成smali文件,然后重新編譯成apk。
將dex文件編譯成smali文件
??將dex文件編譯成smali文件,我們需要下載baksmali.jar文件,下載baksmali.jar文件之后,就可以通過以下命令將dex文件編譯成smali文件了:
java -jar baksmali.jar smaliTest.dex 復制代碼如:你要編譯的dex文件是testSmali.dex則輸入的命令是
java -jar basksmali.jar testSmali.dex 復制代碼如果編譯成功,此時會生成一個out目錄,out目錄里面的文件就是smali文件了。有時可能會遇到下面的錯誤
Exception in thread "main"
com.beust.jcommander.MissingCommandException: Expected a command, got classes.dexat
com.beust.jcommander.JCommander.parseValues(JCommander.java:725)at
com.beust.jcommander.JCommander.parse(JCommander.java:304)at
com.beust.jcommander.JCommander.parse(JCommander.java:287)at org.jf.baksmali.Main.main(Main.java:90)
這時你只要將上面的命令換成
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
掃碼關注公眾號,回復“獲取資料”有驚喜總結
以上是生活随笔為你收集整理的反编译之将脱壳后的dex文件重新打包成apk的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: P2521 [HAOI2011]防线修建
- 下一篇: 私.Modbus测试_ZC02_串口方式