在Android的ART虚拟机使用的oat文件中,其实是包含了一个完整的dex文件的。可以通过解析oat文件将dex文件的偏移和长度都检索到,然后再将这段数据单独读取出来存成dex文件就可以了。
当然,自己可以动手写一个提取的程序,逻辑不复杂。
但是,程序员都是很懒的,如果已经有别人免费提供了这类工具,就绝不会自己动手写。
经过一番查找,发现了一个比较好用的工具,叫做dextra(http://newandroidbook.com/tools/dextra.html),可以从官方网站上将其下载下来。在压缩包里,提供了三个可执行文件,一个是给Mac OS平台用的(dextra),一个是给Linux平台用的(dextra.ELF64),还有一个是可以直接在Android手机上运行的(dextra.armv7)。
对于前两个就不提了,直接解压缩,修改执行权限就可以运行了。
而如果要在手机上运行,最好在root过的手机上,并且将dextra.armv7放置到/system/xbin目录下,将其改名成dextra并加上可执行权限。
使用起来很简单,要想从指定的oat(一般在手机上还是以odex结尾)文件中提取dex文件,可以使用下面的命令:
dextra -dextract <OAT_FILE>
这时候,等程序执行完后,会在当前目录下生成一个dex文件,可以直接对其进行分析。
当然dextra还有很多其它的功能,以后用到的时候再说。