- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3讲 字符串安全(二)(2014年3月5日)
第3讲字符串安全(二)
栈粉碎、代码注入和弧注入
缓冲区溢出缓解策略探讨
计算机学院 徐国爱
xga@
本讲内容安排
1 栈粉碎
2 代码注入
3 弧注入
4 缓解策略
5 著名的漏洞
1.1 栈粉碎及其危害
当缓冲区溢出覆写分配给执行栈内存中的数据
时,就会导致栈粉碎(stack smashing)
这种情况会对程序的可靠性和安全性造成严重
的后果
覆写自动变量会破坏数据的完整性,在某些情况下
也可能会引发安全漏洞(例如,在一个包含UID的
变量被覆写的情况下)
覆写控制转移的指针地址可执行任意代码,一个常
见的例子是覆写返回地址(该地址也位于栈中)
覆写帧或基于栈的异常处理指针、函数指针或其他
控制将导致控制转移
1.2 示例程序的程序栈
图2-9所示的密码程序示例在Windows XP环境
下用Visual C++ 2003编译,就容易遭受栈粉碎
攻击
程序在调用IsPasswordOkay()之前,栈中包含
的信息如图2-16所示,其中含有保存
IsPasswordOkay()函数返回状态的局部变量的
内存,以及调用者的帧指针和返回地址
当程序执行IsPasswordOkay()函数时,栈中包
含的信息如图2-17所示。请注意,Password
数组和main()函数的返回地址都位于栈中,并
且main()函数的返回地址的位置位于Password
数组之后
当程序从IsPasswordOkay()返回时(如图2-18
所示),栈恢复到原来的状态,程序根据从
IsPasswordOkay()函数返回的值继续执行
1.3 简单的栈粉碎
由于Password数组只能包含最多11个字符加上
结尾的空字符,因此该程序存在一个安全缺陷。
如图2-19所示,可以通过输入
“ 12345678901234567890”这样的有着20个字
符的密码造成程序崩溃,从而很容易地暴露这
个缺陷。
由于20个字节是用户输入的,加上用作结尾的
空字符,因此实际上存储该字符串所需要的内
存是21个字节。但是,由于可用于存储密码的
空间仅为12字节,按中用来存储其他信息的9
个字节(21-12=9 )就被密码数据覆写了。
图2-20展示了被20个字节的密码搅乱后的程序
栈。请注意,调用者的帧指针、返回地址以及
PwStatus变量的一部分存储空间都已经被搅乱
了。
图2-20 由20个字节的密码所导致的栈破坏
您可能关注的文档
最近下载
- 兴边富民工程实施方案(3篇).docx
- 苏科版八年级数学上册压轴题攻略专题03解题技巧专题:判定三角形全等的基本思路压轴题三种模型全攻略(原卷版+解析).docx VIP
- 卡通手绘风班干部竞选自我介绍PPT模板(二零二五学期版).pptx VIP
- 带锯机安全生产操作规程.pptx
- 第3课 古代印度 课件(共34张PPT).pptx VIP
- 公共政策3政策的资料搜集与方法剖析.ppt VIP
- 专题04 解题技巧专题:判定三角形全等的基本思路压轴题三种模型全攻略(解析版).docx VIP
- 2025年健康管理师技能证书全国考试题库(含答案).pdf VIP
- 写景抒情散文阅读.doc VIP
- 中小学班级卫生值日表 模板.docx VIP
文档评论(0)