dex和odex相互转换

一、dex和odex

dex是安卓dalvik虚拟机的可执行文件,可以在导出的apk文件里用解压缩软件直接打开。odex是经过优化过的dex。odex一种是从apk程序中提取出来的,与apk文件存放在同一目录,文件后缀为odex,这类odex文件多是Android ROM的系统程序;另一种缓存文件,这类odex仍以dex为后缀,存放在cache/dalvik-cache目录下。存放文件名格式为“apk路径@apk名@class.dex”,例如“[email protected]@[email protected]”,表示/system/app目录下的Calculator.apk程序的odex文件。

二、dex转换为odex

使用dexopt-wrapper可以将dex转换为odex。dexopt-wrapper在安卓2.3以前的源码中可以找到。将dex-wrapper编译后放到手机中。

adb push dexopt-wrapper /data/local
adb shell chmod 777 /data/local/dexopt-wrapper

随意从apk文件中提取一个dex文件,将其改名为classex.dex,zip将其压缩后改名为HelloDex.zip

adb push HelloDex.zip /data/local
adb shell
cd /data/local
./dexopt-wrapper HelloDex.zip HelloDex.odex

如果执行无错误会有如下输出

./dexopt-wrapper HelloDex.zip HelloDex.odex
--- BEGIN ‘HelloDex.zip‘ (bootstrap=0) ---
--- waiting for verify+opt, pid=721
--- would reduce privs here
--- END ‘HelloDex.zip‘ (success) ---

当前目录会有HelloDex.odex文件。现在将其导出方便以后操作。

adb pull /data/local/HelloDex.odex d:\

三、odex转换为dex

odex转换为dex的原理就是先将odex转为smali文件,然后将smali文件转为dex文件。需要下载smali.jar和baksmali.jar。

java -jar baksmali.jar -x HelloDex.odex

可能会有如下错误:

将手机中的/system/framework文件夹导出。放入odex目录下的framework文件夹内。

执行命令

java -jar baksmali.jar -x HelloDex.odex -d framework  //-d 表示指定framework目录

如果无错误会无任何输出,工作目录最终如下,out目录为导出的smali保存目录。

接下来将smali转换为dex

执行命令

java -jar smali.jar out -o OutHelloDex.dex  //将out目录转换为OutHelloDex.dex文件

如果无错误无任何输出。当前目录下会生成OutHelloDex.dex文件。

四、相关下载

所有下载

时间: 2024-10-29 04:48:02

dex和odex相互转换的相关文章

android 反编译(dex 和 odex),非脑残转帖,绝对可靠

Android 反编译 反编译odex文件(例如framework.odex),若是反编译dex,直接第4步 1.由于反编译odex的工具在D:\Develop tools\android反编译工具\odex中,因此为了执行命令方便一点在odex文件夹里面,将system的文件夹结构给新建一下,将反编译的odex中所引用的所有包都放到对应的目录下 system----- |-------app |-------framework 2.java -jar baksmali-2.0.3.jar -d

June 26,2014---->Binder(IPC),Dalvik ,DEX/ODEX

1.Binder(IPC) Linux进程之间要能够互相通信,从而共享资源和信息.所以,操作系统内核必须提供进程间的通信机制(IPC,Inter-Process Communication). IPC机制种类:采用命名管道(name pipe),消息队列(message queue),信号(signal),内存共享(share memory); 在Android终端上的应用软件的通信几乎看不到这些IPC通信方式,取而代之的是Binder方式. Binder是通过Linux的Binder Driv

使用 libdvm.so 内部函数dvm* 加载 dex

首先要清楚,odex只是对代码段(我将dex文件与elf文件类比,大家都将执行文件分成不同的段)作优化,而其它用于类反射信息的段都应用原来的dex,所以odex文件内部还包含了一个dex. 打开一个dex或一个odex文件,就是要将其中用于类反射的信息加载到虚拟机运行时中.对于打开一个odex文件,目的也是要将其中包含的dex部分的信息进行加载. dalvik(libdvm.so)打开dex文件,实质就是要将dex里的反射信息加载到一个DexFile组织的结构体.这个结构有一个查找表,DexCl

运行时动态修复dex

0x00 本文的源代码已经上传至github,地址为https://github.com/jltxgcy/DynamicFixDex.在Android2.3模拟器上可以运行. ForceApkObj:用于动态加载的apk.类似于Android中的Apk的加固(加壳)原理解析和实现一文中的ForceApkObj工程. FixDex:用于分离ForceApkObj里面的classes.dex,把他分离为classes_fix.dex和data.so,具体情况我们后来介绍. DynamicDex:用于

Android开发了解——ODEX

ODEX是安卓上的应用程序apk中提取出来的可运行文件,即将APK中的classes.dex文件通过dex优化过程将其优化生成一个·dex文件单独存放,原APK中的classes.dex文件会保留.这样做可以加快软件的启动速度,预先提取,减少对RAM的占用,因为没有odex的话,系统要从apk包中提取dex再运行. 效果 所谓Odex,是由android软件中的classes.dex生成的,Odex化即是把那个文件预先提取出来作用是能加快软件加载速度和开机速度.不过Odex也有缺点,那就是有时候

浅析dex文件加载机制

我们可以利用DexClassLoader来实现动态加载dex文件,而很多资料也只是对于DexClassLoader的使用进行了介绍,没有深入讲解dex的动态加载机制,我们就借助于Android4.4的源码来探索.先从一个简单的动态加载dex文件开始 具体实现细节可以参考这篇文章AndroidDex数据动态加载技术 Android4.4的源码在百度网盘分享: Android 4.4源码下载 先是我们要封装到text.jar文件中的很简单的调用函数,只是简单的产生Toast: /* * 对外接口 *

android脱壳之DexExtractor原理分析[zhuan]

http://www.cnblogs.com/jiaoxiake/p/6818786.html内容如下 导语: 上一篇我们分析android脱壳使用对dvmDexFileOpenPartial下断点的原理,使用这种方法脱壳的有2个缺点: 1.  需要动态调试 2.  对抗反调试方案 为了提高工作效率, 我们不希望把宝贵的时间浪费去和加固的安全工程师去做对抗.作为一个高效率的逆向分析师, 笔者是忍不了的,所以我今天给大家带来一种的新的脱壳方法——DexExtractor脱壳法. 资源地址: Dex

Android 安全开发之 ZIP 文件目录遍历

1.ZIP文件目录遍历简介 因为ZIP压缩包文件中允许存在"../"的字符串,攻击者可以利用多个"../"在解压时改变ZIP包中某个文件的存放位置,覆盖掉应用原有的文件.如果被覆盖掉的文件是动态链接so.dex或者odex文件,轻则产生本地拒绝服务漏洞,影响应用的可用性,重则可能造成任意代码执行漏洞,危害用户的设备安全和信息安全.比如近段时间发现的"寄生兽"漏洞.海豚浏览器远程命令执行漏洞.三星默认输入法远程代码执行漏洞等都与ZIP文件目录遍历有

android脱壳之DexExtractor原理分析

导语: 上一篇我们分析android脱壳使用对dvmDexFileOpenPartial下断点的原理,使用这种方法脱壳的有2个缺点: 1.  需要动态调试 2.  对抗反调试方案 为了提高工作效率, 我们不希望把宝贵的时间浪费去和加固的安全工程师去做对抗.作为一个高效率的逆向分析师, 笔者是忍不了的,所以我今天给大家带来一种的新的脱壳方法--DexExtractor脱壳法. 资源地址: DexExtractor源码:https://github.com/bunnyblue/DexExtracto