android 5.0.1 libdvm.so,Android逆向进阶—— 脱壳的奥义(基ART模式下的dump)

本文作者:i春秋作家HAI_ZHU

0×00 前言

市面上的资料大多都是基于Dalvik模式的dump,所以这此准备搞一个ART模式下的dump。

Dalvik模式是Android 4.4及其以下采用的模式,之后到了Android 5.0 之后就是ART模式,关于这两个模式的详细内容,请自行百度,如果在文章看不来的地方,可以翻翻之前的文章。如果有问题也可以私聊我。

废话不多说,直接上操作。

内容:demo 动态 dump 出 dex文件

环境说明

1.系统 小米 9.0

2.ida 7.0

0×01 demo 动态 dump 出 dex文件

1.启动ida 端口监听

1.1启动Android_server 服务

ab7134d4c5e48fcddfa709c4fff8dc03.png

1.2端口转发

46fd1e5f020d04c34cefb6ac4df8c765.png

1.3软件进入调试模式

c3ac5e564aceef7d7565a0b9de589104.png

2.ida 下断

2.1 attach  附加进程

4a0032a308c76dafda0d3626e44b0b09.png

2.2 断三项

b5adc72abf5463c3605f2517ab4b05b5.png

2.3 选择进程

200217b5b95abfc551355cb1515b5360.png

2.4 打开Modules

搜索art

82c6956bca6f1d028a37a6e33bcb3ef4.png

PS:小知识

Android 4.4版本之前 系统函数在libdvm.so

Android 5.0之后 系统函数在libart.so

2.5 打开Openmemory()函数

在libart.so中搜索Openmemory函数并且跟进去。

49607fe4b2fb272baa0194f930b37d89.png

PS:小知识

一般来说,系统dex都会在这个函数中进行加载,但是会出现一个问题,后面说。

2.6 下断点

f6f3a9cb26012ebd240f477134a67823.png

3.运行程序到下断处

3.1 jdb转发运行程序

f70809aabd7ba8741457426bda94ac24.png

3.2 查看IDA运行

成功下断,并且运行到我们下断的地方。

a6c31465d79c0b2ec724700ca8eebd4a.png

3.3 查看 dex的位置

打开寄存器窗口,可以看到R1就是我们的dex

a543ade1b0831a5231d2933c9fbcff4b.png

然后在Hex窗口打开R1。

915c6f490ea3654012e0ff79484a6d37.png

很明显就看到了dex文件的二进制结构。如果不明白可以看看之前的dex文件分析。

3.4 提取关键信息

第一个关键信息:地址偏移:0xF35CA328

f33aa30eb6197f1cbe45b60f6b4d85f2.png

第二个关键信息:文件偏移:70 35 01 00,转换一下就是 0×00013570

12b2c925b4b8f0a37284d8623894c64e.png

使用16进制加法器进行相加,F35DD898

39782ebf9991dd19eed93b0e58d6b90f.png

4. dump

4.1 使用脚本进行dump

staticmain(void){    auto fp, begin, end, dexbyte;    //打开或创建一个文件fp = fopen(“d:\\dump.dex”, “wb”);    //dex基址begin=  0xF34C6320;    //dex基址 + dex文件大小end= begin+ 0×00013570;    for( dexbyte = begin; dexbyte < end;     dexbyte ++ ){//按字节将其dump到本地文件中fputc(Byte(dexbyte), fp);        }}

4.2 脚本dump run

脚本填写好了之后,点击run即可。

01e3e81f6db6eae39386387c4f90fe43.png

4.3 成功dump

ee1406b7daa7c33de9d66b87e6fcc4a7.png

0×02 后续

这里dump出来的dex还是和原来的dex有一些区别的,要进行一些修复才可以。关于修复的内容还在探讨中,如果有大佬路过指教一二,感激不尽。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值