资源描述:
《如何反编译android 5.0 framework》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、如何反编译Android5.0framework文/腾讯优测储俊雄在Android平台,对于和硬件交互相关的模块来说,比如:和双卡对应的Telephony模块、和拍照对应的Camera模块,以及Bluetooth模块等等,不同厂商会不同程度的修改Androidframework层对应的原生模块代码来达到他们自己的目的,这就给应用层的开发人员带来了让他们很头疼的适配问题,严重会导致crash等问题。为了更好的适配,我们不得不对framework层进行反编译,在Android更新到5.0后,开发人员对fra
2、mework的反编译也出现了新的变化。一.相关背景介绍在5.0以前,我们可以直接从手机system目录导出的framework文件夹根目录里找到相关的odex文件或者相关dex文件(解压jar文件或apk文件得到),然后通过smali和dex2jar等工具就可以成功反编译得到我们所需要的东西。但到了5.0,出现了两个问题。1.以前分散在framework文件夹根目录里的那些odex文件全部集中在了framework文件夹中的arm(或arm64)子文件夹中,而且通过正常的反编译发现这些odex并不是像5
3、.0以前一样是我们所需要的东西。5.1-9,,services,andmakethecitymoreattractive,strengtheningpublictransportinvestment,establishedasthebackboneoftheurbanrailtransitmulti-level,multi-functionalpublictransportsystem,thusprotectingtheregionalpositionandachieve(arm文件夹里的各种odex文
4、件)1.在arm(arm64)子文件中出现了两个我们在5.0以前没有见过的东西:boot.oat文件和boot.art文件,这两个文件引起了我们的兴趣,也是我们接下来分析的重点。(arm文件夹里重要的boot.oat文件和boot.art文件)5.1-9,,services,andmakethecitymoreattractive,strengtheningpublictransportinvestment,establishedasthebackboneoftheurbanrailtransitmul
5、ti-level,multi-functionalpublictransportsystem,thusprotectingtheregionalpositionandachieve二.对oat文件的分析说到这个oat文件和art文件,我们不能不提Google在4.4版本以后新引入的ART运行时,这里简要的说一下:我们都知道在4.4以前,Android应用程序运行的核心基础是Dalvik虚拟机,这个Dalvik虚拟机原先是apache开源的一个JVM的优化版本,而Google又对Dalvik虚拟机进行了特
6、别的优化来适应Android系统,所以Dalvik虚拟机本质就是JVM,尽管Google花了大力气优化Dalvik虚拟机,但是效果目前来看还不能让Google满意,为了Android系统的流畅度能更上一层楼,在Android进化到4.4版本时,Google决定抛弃Dalvik虚拟机引入全新的ART运行时,其实,ART运行时依然还是Java虚拟机的实现,只是ART运行时更高效更好用。(左边对应Dalvik虚拟机,右边对应ART运行时【原图出处:罗升阳——AndroidART运行时无缝替换Dalvik虚拟机
7、的过程分析】)5.1-9,,services,andmakethecitymoreattractive,strengtheningpublictransportinvestment,establishedasthebackboneoftheurbanrailtransitmulti-level,multi-functionalpublictransportsystem,thusprotectingtheregionalpositionandachieve和Dalvik虚拟机相比,ART运行时执行的是本地
8、机器码,虽然Dalvik虚拟机也使用JIT(Just-In-Time)将dex字节码翻译成本地机器码,但是是在应用程序的运行过程中进行的,所以在效率方面还无法和ART运行时相比,ART运行时会在应用程序安装的时候就通过dex2oat将dex字节码翻译成本地机器码,而这个由ART翻译出来的本地机器码会对应着一个oat文件。(函数run_dex2oat通过调用dex2oat来将dex字节码翻译成本地机器码)其实,oat文件是一种特殊的ELF文件