- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
如何反编译Android 5.0 framework
如何反编译Android 5.0 framework
文/腾讯优测 储俊雄
在Android平台,对于和硬件交互相关的模块来说,比如:和双卡对应的Telephony模块、和拍照对应的Camera模块,以及Bluetooth模块等等,不同厂商会不同程度的修改Android framework层对应的原生模块代码来达到他们自己的目的,这就给应用层的开发人员带来了让他们很头疼的适配问题,严重会导致crash等问题。为了更好的适配,我们不得不对framework层进行反编译,在Android 更新到5.0后,开发人员对framework的反编译也出现了新的变化。
相关背景介绍
在5.0以前,我们可以直接从手机system目录导出的framework文件夹根目录里找到相关的odex文件或者相关dex文件(解压jar文件或apk文件得到),然后通过smali和dex2jar等工具就可以成功反编译得到我们所需要的东西。但到了5.0,出现了两个问题。
以前分散在framework文件夹根目录里的那些odex文件全部集中在了framework文件夹中的arm(或arm64)子文件夹中,而且通过正常的反编译发现这些odex并不是像5.0以前一样是我们所需要的东西。
(arm文件夹里的各种odex文件)
在arm(arm64)子文件中出现了两个我们在5.0以前没有见过的东西:boot.oat文件和boot.art文件,这两个文件引起了我们的兴趣,也是我们接下来分析的重点。
(arm文件夹里重要的boot.oat文件和boot.art文件)
对oat文件的分析
说到这个oat文件和art文件,我们不能不提Google在4.4版本以后新引入的ART运行时,这里简要的说一下:我们都知道在4.4以前,Android 应用程序运行的核心基础是Dalvik虚拟机,这个Dalvik虚拟机原先是apache开源的一个JVM的优化版本,而Google又对Dalvik虚拟机进行了特别的优化来适应Android系统,所以Dalvik虚拟机本质就是JVM,尽管Google花了大力气优化Dalvik虚拟机,但是效果目前来看还不能让Google满意,为了Android系统的流畅度能更上一层楼,在Android进化到4.4版本时,Google决定抛弃Dalvik虚拟机引入全新的ART运行时,其实,ART运行时依然还是Java虚拟机的实现,只是ART运行时更高效更好用。
(左边对应Dalvik虚拟机,右边对应ART运行时【原图出处:罗升阳——Android ART运行时无缝替换Dalvik虚拟机的过程分析】)
和Dalvik虚拟机相比,ART运行时执行的是本地机器码,虽然Dalvik虚拟机也使用JIT(Just-In-Time)将dex字节码翻译成本地机器码,但是是在应用程序的运行过程中进行的,所以在效率方面还无法和ART运行时相比,ART运行时会在应用程序安装的时候就通过dex2oat将dex字节码翻译成本地机器码,而这个由ART翻译出来的本地机器码会对应着一个oat文件。
(函数run_dex2oat通过调用dex2oat来将dex字节码翻译成本地机器码)
其实,oat文件是一种特殊的ELF文件(关于ELF文件的具体内容可以Google相关内容),通过前面的介绍可以知道它包含本地机器码(从dex翻译而来),此外还包含有原来的dex文件内容,本质上它依然是一种预编译文件。这就告诉我们,oat文件就是把过去的很多dex文件一起合并输入然后由ART运行时在安装时翻译成本地的机器码然后再打包转换输出就OK了,同样的道理,我们知道system分区的文件都是在厂商在压制ROM时打包进去的, framework文件夹里面的内容尤其是各种dex文件等会在系统启动后通过arm(或arm64)子文件夹里的boot.art文件来指定启动一个ART运行时实例,然后把这些classes.dex等dex文件合并输入到ART再翻译成本地机器码打包成oat文件,这就是我们需要的核心文件boot.oat的大致生成过程(具体的过程比较复杂,详细情况可以自行Google相关内容)。到此,我们简单的介绍了oat文件的来历,oat文件里有什么,以及oat文件的生成过程。
三. 反编译的核心:“拆开”oat文件
有了以上的了解,我们可以知道,反编译boot.oat文件的核心步骤就是把之前很多dex合并起来生成的oat文件拆开,之前我们在oat是怎么来的时候提到过,ART运行时会通过dex2oat把很多dex文件合并打包然后翻译转换成oat,所以相同的道理,如果要有一个oat2dex工具就好了,可喜的是,真的有oat2dex工具的存在,有了这个工具,我们就可以把我们需要的boot.o
您可能关注的文档
最近下载
- 蔬菜西甜瓜种子生产技术 种子生产技术、蔬菜西甜瓜种子生产技术 菜豆种子生产技术.pptx VIP
- 《建筑防火通用规范GB 55037-2022》解读与培训.pptx VIP
- 纳米科技概论-第二章纳米材料-表征(结构)解析.ppt VIP
- 《DB22T 1721-2012 林业木材加工劳动定额》.pdf
- 2021钉钉数字化管理师正确选择答案汇总 .pdf VIP
- 守正创新实干担当心得体会四篇.docx VIP
- 新视野大学英语(第四版)读写教程3(思政智慧版)外研社编B3U3 Section A.pptx VIP
- 中考语文阅读理解《怀念蛙鼓》含答案.docx VIP
- 医用红外线体温计(额温枪)注册申报资料全套完整模板.docx
- 《自动驾驶出租汽车 第1部分:车辆运营技术要求》.pdf VIP
原创力文档


文档评论(0)