反编译之将脱壳后的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

扫码关注公众号,回复“获取资料”有惊喜