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有一些区别的,要进行一些修复才可以。关于修复的内容还在探讨中,如果有大佬路过指教一二,感激不尽。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/433156.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python bunch制作可导入数据_Python bunch包_程序模块 - PyPI - Python中文网

bunch是一个支持属性样式访问的字典&#xff0c;一个la javascript。>>> b Bunch()>>> b.hello world>>> b.helloworld>>> b[hello] "!">>> b.helloworld!>>> b.foo Bunch(lolTrue)>>> b.foo.lo…

浪潮之巅 笔记

14.2 诺威格(Peter Norvig&#xff0c;Google研究院主任&#xff0c;ACM Fellow&#xff0c;人工智能专家)定理&#xff1a;当一个公司的市场占有率超过50%后&#xff0c;就无法再使市场占有率翻翻了。在一个市场占有主导地位的公司必须不断开拓新的财源&#xff0c;才能做到长…

Linux下gSOAP的使用 (c++)

1、下载gSOAP在gSOAP官网中可以找到最新的gSOAP安装包以及相关的文档gSOAP官网&#xff1a;http://www.cs.fsu.edu/~engelen/soap.htmlgSOAP下载地址&#xff1a;http://sourceforge.net/projects/gsoap2/files/ 2、安装gSOAPa、解压zip压缩包命令&#xff1a;unzip gsoap_2.7.…

android+3.0新加的动画,Android动画片

使用Android两年多了&#xff0c;工作中的动画也动能应付&#xff0c;自认为Android中的动画自己也能用个八九不离十&#xff0c;结果我在学习[Periscope点赞效果](http://www.jianshu.com/p/03fdcfd3ae9c)的时候发现动画的这些高级功能我从没用过、也没见过&#xff0c;静下来…

xy坐标转换度分秒_经纬度转换XY坐标软件

经纬度与XY坐标转换工具是一款非常好用的坐标转换器&#xff0c;能够将经纬度转换为XY坐标&#xff0c;对于从事地理相关工作者还是很有用的。有了它就不必去记住公式了&#xff0c;只需输入数值&#xff0c;点击一下就行了。软件功能1、度分秒和度的转换2、经纬度和xy的转换3、…

LeetCode-Scramble String

哎&#xff0c;难题又不会做&#xff0c; 思路没有什么难度&#xff0c; 关键是要把问题思考透彻&#xff0c; 要考虑的要点还是挺多的&#xff0c;不容易一下子都考虑到&#xff1b; 我开始的思路是按照树的根去递归的&#xff0c; 这样就必须要没有重复元素&#xff0c;因为需…

在线打开html文件,html是什么文件?html文件怎么打开?

html是什么&#xff1f;html即超文本标记语言&#xff0c;现在大多网页都是html的格式。而所谓的html文件是一种超文本文件&#xff0c;其中超文本可以是图片或音乐等非文字元素&#xff0c;使用很广泛。但是很多用户都不太明白html是什么文件&#xff1f;也不清楚html文件要如…

gsoap使用心得! (win32)

最近换了个工作环境&#xff0c;现在在大望路这边上班&#xff0c;呵&#xff0c;刚上班接到的任务就是熟悉gsoap&#xff01;废话少说&#xff0c;现在开始gSoap学习&#xff01;gSOAP是一个夸平台的&#xff0c;用于开发Web Service服务端和客户端的工具&#xff0c;在Window…

hbase中列簇和列_为什么不建议在hbase中使用过多的列簇

我们知道&#xff0c;hbase表可以设置一个至多个列簇(column families)&#xff0c;但是为什么说越少的列簇越好呢&#xff1f;官网原文&#xff1a;HBase currently does not do well with anything above two or three column families so keep the number of column familie…

html怎么置顶导航栏,css怎么实现滚动页面导航栏固定在顶部

css怎么实现滚动页面导航栏固定在顶部(吸顶效果)功能&#xff1a;当网页向下滚动时&#xff0c;导航栏一直在固定在顶部一、css设置这里主要用到css中position中的relative与fixed&#xff1b;其中relative是生成相对定位的元素&#xff0c;相对于其正常位置进行定位。fixed是生…

numpy读取csv_Numpy——IO操作与数据处理

一、问题&#xff1f;大多数数据并不是我们自己构造的&#xff0c;存在文件当中。我们需要工具去获取&#xff0c;但是Numpy其实并不适合去读取处理数据&#xff0c;这里我们了解相关API&#xff0c;以及Numpy不方便的地方即可。二、Numpy读取genfromtxt(fname[, dtype, commen…

Pydiction : VIM上的PYTHON代码自动补全插件

http://www.vim.org/scripts/script.php?script_id850 1、下载Pydiction其中有4个文件&#xff1a;complete-dict //PYTHON 的KEYWORD集pydiction.pypython_pydiction.vim //让VIM认识PYTHONREADME.txt //说明书 2、把上面的python_pydiction.vim拷到ftplugin 目录下 3、把其它…

android 中radiogroup滑动切换,巧妙实现缺角radiogroup控制多个fragment切换和滑动

在android开发中&#xff0c;用一个radiogroup控制多个fragment切换是十分常见的需求。但是如果fragment是一个ListView&#xff0c;如何保证滑动的时候通过缺角可以看到下面的listview是一个难点。直接上图:(1)完美效果(2)较差效果另外&#xff0c;不妨假设缺角的高度是5dp&am…

java vo转map_JAVA Map转换为Bean或VO

JAVA Map转换为Bean或VOJava.util中的集合类包含Java中某些最常用的类。Map提供了一个更通用的元素存储方法。Map集合类用于存储元素对(称作“键”和“值”)&#xff0c;其中每个键映射到一个值&#xff0c;在java编程中使用的相当之多。但是当我们进行业务逻辑或数据库处理时&…

应用市场中包名(package name)的唯一性

一般的应用商店&#xff0c;在开发者上传应用(APP)的时候&#xff0c;都会对应用的包名进行唯一性的校验。如果此时&#xff0c;用户上传的应用的包名与数据库中的已有的APP的包名一样&#xff0c;那么正常情况下&#xff0c;该应用就不能上传&#xff0c;而弹出提示说&#xf…

linux中线程的挂起与恢复(进程暂停)

今 天 在网上查了一下 linux中对进程的挂起与恢复的实现&#xff0c;相关资料少的可怜&#xff0c;大部分都是粘贴复制。也没有完整详细的代码。故自己整理了一下程序流程为&#xff1a;主线程创建子线程&#xff08;当前子线程状态为stop停止状态&#xff09;&#xff0c;5秒后…

荣耀智慧屏评测 鸿蒙OS加持,荣耀智慧屏评测:鸿蒙OS加持 面向未来的超智能电视...

原标题&#xff1a;荣耀智慧屏评测&#xff1a;鸿蒙OS加持 面向未来的超智能电视 来源&#xff1a;TechWeb.com.cn当华为选择在今年公布鸿蒙OS系统后&#xff0c;很多人都在期待它的庐山真面目。无论是以后非常时期不再受制于人&#xff0c;或是循序渐进将系统过渡给自家设备&a…

c位边上还有什么位_【一点资讯】那些有趣而搞笑的GIF动画:为让出c位,站边上拍照还是谦虚礼貌的 www.yidianzixun.com...

1_为让出c位&#xff0c;站边上拍照&#xff0c;还是谦虚礼貌的&#xff0c;2_最后都吓死我了&#xff01;3_啥情况&#xff1f;4_今年工作太难了&#xff0c;回家种地卖水果吧5_除了电池差了一点&#xff0c;12应该是最完美的手机了吧精选搞笑图文&#xff1a;小王去女朋友家里…

两个有用的minicom命令

minicom执行后&#xff0c;一个屏幕显示的字符有限&#xff0c;如果需要查看之前的串口通讯记录&#xff0c;可以使用Ctrl-A B使用进入串口通讯记录查询模式。如果需要将minicom的串口通讯记录保存到某个文件&#xff0c;可以在minicom刚启动时用Ctrl-A L命令进入串口通讯捕捉模…

2021河南固高高考成绩查询,河南信阳最好的4所高中,前三所学霸如云,看看有没有你的母校?...

河南省信阳市处于豫之南&#xff0c;鄂之北。南边是连绵的群山&#xff0c;北边是广袤的平原。千里淮河&#xff0c;曲折盘旋&#xff0c;它的源头便是这里。都说信阳是一个神奇的地方&#xff0c;一点儿也不为过&#xff0c;狮河穿城而过&#xff0c;周围群山环抱&#xff0c;…