- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
5.4.1 实例:缓冲区溢出及其原理
1.缓冲区溢出实例一
实验环境:Linux操作系统。
第1步:编写源程序。编写C语言源程序,如图5-14所示,保存为buffer_flow.c文件。
第2步:编译源程序。如图5-15所示,执行# gcc buffer_flow.c -o buffer_flow.o命令,编译源程序。
图5-14 buffer_flow.c文件 图5-15 编译源程序
第3步:执行程序。如图5-15所示,执行# ./buffer_flow.o命令,输出结果99999。通过分析主函数的流程,应该输出1,可是为什么输出99999呢?原因在于funtion()函数。
2.buffer_flow的分析
下面对buffer_flow.o程序在内存中的分布情况以及执行流程进行分析。
一个程序在内存中通常分为:程序段、数据段、堆和栈。
(1)程序段:存放着程序的机器码和只读数据。
(2)数据段:存放的是程序中的静态数据和全局变量。
(3)堆、栈:存放动态数据及局部变量。
x86平台的虚拟地址空间是0x0000 0000~0xffff ffff,前3GB(0x0000 0000~0xbfff ffff)是用户空间,后1GB(0xc000 0000~0xffff ffff)是内核空间,他们的位置如图5-16所示。
栈是一块保存数据的连续内存,一个名为栈指针(SP,指向栈顶部)的寄存器指向栈的顶部,栈的底部在一个固定的地址。除了SP之外,为了使用方便还有指向帧内固定地址的指针称做帧指针(FP)。从理论上说,局部变量可以用SP加偏移量来引用。栈由逻辑栈帧组成,一个函数对应一个栈帧,当调用函数时逻辑栈帧被压入栈中,栈帧包括函数的局部变量(如果函数有局部变量)、返回地址、EBP和被调函数的形参。程序执行结束后,局部变量的内容将会丢失,但是不会被清除。当函数返回时逻辑栈帧被从栈中弹出,然后弹出EBP,恢复栈到调用函数时的地址,最后弹出返回地址到EIP从而继续运行程序。
调用函数function(1, 2, 3)的过程如图5-17所示:
图5-16 进程地址空间 图5-17 调用函数function(1, 2, 3)的过程
首先把参数压入栈;在C语言中参数的压栈顺序是反向的,以从后往前的顺序将function的3个参数3、2、1压入栈中。
然后保存指令寄存器(IP)中的内容作为返回地址(return2)压入栈中;第3个放入栈的是基址寄存器EBP(即sfp)。
接着把当前的栈指针(SP)复制到EBP,作为新栈帧的基地址(sfp,栈帧指针)。
最后把SP减去适当的数值,将局部变量(buffer和ret)压入栈中。
执行第8行语句ret=(int*)(buffer1+16);后,指针ret指向return2所指的存储单元,执行第9行语句(*ret)+=7;后,调用函数function()后的返回地址(return2所指的存储单元)指向了第17行,第16行被隔过去了,因此,该程序的输出结果是99999。
3.缓冲区溢出实例二
实验环境:Linux操作系统。
第1步:编写源程序。编写C语言源程序,如图5-18所示,保存为buffer_flow_2.c文件。
第2步:编译源程序。如图5-19所示,执行# gcc buffer_flow_2.c -o buffer_flow_2.o命令,编译源程序。
第3步:执行程序。如图5-19所示,执行# ./buffer_flow_2.o命令,输出结果“sh-3.2#”,表明溢出成功。
请读者结合图5-20对buffer_flow.o程序在内存中的分布情况以及执行流程进行分析。
图5-18 buffer_flow_2.c文件
图5-19 编译源程序
图5-20 程序执行流程
您可能关注的文档
- 西方文学名著导引全套配套课件蒋承勇卜伽丘的《十日谈》:人欲是天然合理的?.ppt
- 西方经济学(第三版)微观经济学黎诣远关于微观经济学第三版课件的修改.doc
- 西方经济学(第三版)微观经济学黎诣远电子教案.ppt
- 西方经济学(第三版)微观经济学黎诣远第一篇 习题解答.doc
- 西方经济学(第三版)微观经济学黎诣远第三篇 习题解答.doc
- 西方经济学(第三版)微观经济学黎诣远第五篇 习题解答.doc
- 西方经济学(第三版)微观经济学黎诣远课程说明.doc
- 触发器教学课件作者含和视频-王立武要点.pptx
- 触发器教学课件作者含和视频-王立武触发器.pptx
- 计应用基础8-2江南水乡.pptx
- 计算机安全技术TOOLS教程课件5.4.2 实例:缓冲区溢出攻击及其防范.doc
- 计算机安全技术TOOLS教程课件5.5.1 实例:arp欺骗.doc
- 计算机安全技术TOOLS教程课件5.6.1 实例:DDoS攻击.doc
- 计算机安全技术TOOLS教程课件5.7.2 实例:Windows中防火墙配置.doc
- 计算机安全技术TOOLS教程课件5.7.3 实例:Linux防火墙配置.doc
- 计算机安全技术TOOLS教程课件5.8.1 实例:使用Snort进行入侵检测.doc
- 计算机安全技术TOOLS教程课件6.1.1 实例:注入攻击MS SQL Server.doc
- 计算机安全技术TOOLS教程课件6.1.2 实例:注入攻击Access.doc
- 计算机安全技术TOOLS教程课件6.4.1 实例:MS SQL Server 2005安全管理.doc
- 计算机安全技术TOOLS教程课件6.5.2 实例:SQL Server 2005自动备份数据库.doc
最近下载
- 食堂用餐协议书范本(2025版).docx VIP
- 中建八局《质量标准化系列做法(主体结构工程)》2022年.pptx VIP
- TD_T 1021-2009县级土地利用总体规划制图规范.pdf VIP
- 粤人版英语五年级下册Review1 Reading and writing 课件.pptx VIP
- 离散数学崔艳荣习题答案.docx VIP
- 人教版八年级体育与健康:学会与他人交往 (2).pptx VIP
- 《水力发电》课件.pptx VIP
- 企业工会助推企业高质量发展.docx VIP
- GB50974-2014 消防给水及消火栓系统技术规范.pdf VIP
- 新风系统入门培训资料.ppt VIP
文档评论(0)