本文作者:i春秋作家HAI_ZHU
HAI_的使用手册(各种好东西)
0x00 前言
Dalvik模式是Android 4.4及其以下采用的模式,之后到了Android 5.0 之后就是ART模式,关于这两个模式的详细内容,请自行百度,如果在文章看不来的地方,可以翻翻之前的文章。如果有问题也可以私聊我。
废话不多说,直接上操作。
内容:demo 动态 dump 出 dex文件
环境说明
1.系统 小米 9.0
2.ida 7.0
0x01 demo 动态 dump 出 dex文件
1.启动ida 端口监听
1.1启动Android_server 服务
data:image/s3,"s3://crabby-images/7322f/7322f73b2bf7abb79948750cb3e73b992e123f0a" alt="图片.png"
1.2端口转发
data:image/s3,"s3://crabby-images/86be2/86be2c24f87c94f7d6456dc2fffc61cc4c120039" alt="图片.png"
1.3软件进入调试模式
data:image/s3,"s3://crabby-images/1f0a1/1f0a1ffef52a0de4df1967c88dab5e9fb9d72c8d" alt="图片.png"
2.ida 下断
2.1 attach 附加进程
data:image/s3,"s3://crabby-images/fdbca/fdbcad5ba1663ed8542afb312364042915b60f96" alt="图片.png"
2.2 断三项
data:image/s3,"s3://crabby-images/06cac/06cacd7fd629adccd81716f390c95c7332e6f185" alt="图片.png"
2.3 选择进程
data:image/s3,"s3://crabby-images/0912e/0912e833166a38507fe3557cc0b5893ce37193d2" alt="图片.png"
2.4 打开Modules
搜索art
data:image/s3,"s3://crabby-images/307ce/307ceb2d53908200527fd56d5df9ae5fe8042ba1" alt="图片.png"
PS:小知识
Android 4.4版本之前 系统函数在libdvm.so
Android 5.0之后 系统函数在libart.so
2.5 打开Openmemory()函数
在libart.so中搜索Openmemory函数并且跟进去。
data:image/s3,"s3://crabby-images/5eb14/5eb1497fcd266d7afc255f79ad65823bde1336f2" alt="图片.png"
PS:小知识
一般来说,系统dex都会在这个函数中进行加载,但是会出现一个问题,后面说。
2.6 下断点
data:image/s3,"s3://crabby-images/654cc/654cc0076e8498c7409314874548b136bf6bfbc5" alt="图片.png"
3.运行程序到下断处
3.1 jdb转发运行程序
data:image/s3,"s3://crabby-images/236f2/236f23292903adb33b6f5fd03d8967163cd96910" alt="图片.png"
3.2 查看IDA运行
成功下断,并且运行到我们下断的地方。
data:image/s3,"s3://crabby-images/81efe/81efe6a3c22ed884692104dbf1fd03335e9bdccd" alt="图片.png"
3.3 查看 dex的位置
打开寄存器窗口,可以看到R1就是我们的dex
data:image/s3,"s3://crabby-images/f29be/f29bea07a609961c36475b443c0d864dee0df80a" alt="图片.png"
然后在Hex窗口打开R1。
data:image/s3,"s3://crabby-images/1fb94/1fb941e8b3e87e7dfee52d91b5755ba660ea7556" alt="图片.png"
很明显就看到了dex文件的二进制结构。如果不明白可以看看之前的dex文件分析。
3.4 提取关键信息
第一个关键信息:地址偏移:0xF35CA328
data:image/s3,"s3://crabby-images/ff72f/ff72f5754997538c0822495a0a83a36b5ed075a6" alt="图片.png"
第二个关键信息:文件偏移:70 35 01 00,转换一下就是 0x00013570
data:image/s3,"s3://crabby-images/937c8/937c84fc5128df888b84efd3dee5a92a3f15b954" alt="图片.png"
使用16进制加法器进行相加,F35DD898
data:image/s3,"s3://crabby-images/51804/51804c3ed8c358dfcf4a88324e9e688f884640ed" alt="图片.png"
4. dump
4.1 使用脚本进行dump
static main(void){ auto fp, begin, end, dexbyte; //打开或创建一个文件 fp = fopen("d:\\dump.dex", "wb"); //dex基址 begin = 0xF34C6320; //dex基址 + dex文件大小end = begin + 0x00013570; for ( dexbyte = begin; dexbyte end; dexbyte ++ ){//按字节将其dump到本地文件中fputc(Byte(dexbyte), fp); }}
4.2 脚本dump run
脚本填写好了之后,点击run即可。
data:image/s3,"s3://crabby-images/31986/319866209b1500f1096f4d4ad7523304f65c4294" alt="图片.png"
4.3 成功dump
data:image/s3,"s3://crabby-images/5c903/5c90325783850f35f6f04dadef347973f8c78c6c" alt="图片.png"
0x02 后续
这里dump出来的dex还是和原来的dex有一些区别的,要进行一些修复才可以。关于修复的内容还在探讨中,如果有大佬路过指教一二,感激不尽。