4.4 Dex 加载流程Native层分析
Java层 Dex加载流程 网上 有很多帖子 都写得很不错 如果感兴趣的话 可以 找几篇看看
大概描述:
DexClassLoader ->
父类BaseDexClassLoader的构造->
new DexPaseList->
makeDexElements->将dex分割 可能有多个Dex(返回一个 Elements[]),赋值给成员变量
LoadDexFile->
DexFile->
OpenDexFile->返回mCookie(DexOrJar)
OpenDexFileNative->
最终调用 OpenDexFileNative-> 进行dex解析
下面一起分析一下 4.4 Dvm虚拟机中 openDexFileNativie
到底做了什么
路径/aosp/dalvik/vm/mk文件/编译 最终 生成 libdvm.so
找到 OpenDexFileNative-> 函数
data:image/s3,"s3://crabby-images/90066/90066390684735f241cda320ed7243c1535353f1" alt=""
先判断是否有无文件 没有 进行 加载 调用 dvmRawDexFileOpen
data:image/s3,"s3://crabby-images/96c60/96c60ed2a05bfb40587fe15737af61e21eb0d20e" alt=""
data:image/s3,"s3://crabby-images/c5ecd/c5ecd0c2c2880d8668144a3361e99fbeca242781" alt=""
data:image/s3,"s3://crabby-images/d718c/d718c07f6936579799452896868a0062fe94fc52" alt=""
data:image/s3,"s3://crabby-images/c3c39/c3c394532bbe2a3002a56a834279a72b5959469f" alt=""
data:image/s3,"s3://crabby-images/2d5e5/2d5e5840f972ccb602edbfebdd49d1d25eeefc2d" alt=""
data:image/s3,"s3://crabby-images/638a6/638a6c2fbbe9be21dde58d8f8effc2acdfb30f4f" alt=""
data:image/s3,"s3://crabby-images/b4ee9/b4ee92b9712d6c7c7c4251171eb53c4086d54a09" alt=""
继续跟进dexFileParse-> 三个参数
1,odex的地址
2,文件长度
3,flag
data:image/s3,"s3://crabby-images/6b776/6b776083f4dec9825a7ee7637fc4653516c1f0c5" alt=""
data:image/s3,"s3://crabby-images/da38e/da38e19a2e2e01a25590bb73ec1241a50336256f" alt=""
data:image/s3,"s3://crabby-images/a6d88/a6d889a06dc5f206e484f1e62294af5632467dd2" alt=""
data:image/s3,"s3://crabby-images/653f2/653f2c3356bc3449ebdc8aee8c724f38d4a8c12c" alt=""
具体函数 如下
data:image/s3,"s3://crabby-images/0ebf8/0ebf8a713381807cda1eae4fbfb81dafbc34a961" alt=""
data:image/s3,"s3://crabby-images/185b3/185b312cae8fc99d887c979424aca0191dc16ebb" alt=""
data:image/s3,"s3://crabby-images/4cd9d/4cd9db2d79440d668eb5717d3cf17ec6c5c38c78" alt=""
data:image/s3,"s3://crabby-images/a5486/a5486845255145da7c416c360f8be3ef77e5222a" alt=""
读取成功 以后 将 pDexOrJar->fileName 进行赋值
将加载以后的mCookie通过调用 addToDexFileTable 添加到 Table中
data:image/s3,"s3://crabby-images/4d7e9/4d7e9d438b1a1445c0700dfe654d8a2789d157a1" alt=""
data:image/s3,"s3://crabby-images/6799e/6799ec8ce769780e8a86f27ac583360da9e72f56" alt=""
到这openDexFileNative 函数 跑完了
最后 返回的就是mCookie
其实返回是一个 DexOrJar
data:image/s3,"s3://crabby-images/1e93a/1e93a5a173633b5106aa8c2de4f910eb07e9766c" alt=""
如果 java层 用到某一个类的话 会调用findClass
从mCookie 进行加载
在代码中 有一个 *gDvm变量,简单说明一下
* gDvm(主要保存了 程序 在 dvm虚拟机的一些数据,
是全局变量,每一个 dvm上面的程序 创建的时候 必须初始化的变量
,也会存放 dex的一些数据 进行缓存 来达到 优化的作用 )
如果对 逆向,脱壳,新技术 感兴趣的 同学 可以加 我Q群 欢迎各位能人志士 一起讨论
欢迎加入故事,群聊号码:773642813
珍惜
2018年10月08日10:32:45
-----------------------------------------------------------------------------------------------------------------------------------------