栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

堆栈常驻缓冲区在64位上溢出?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

堆栈常驻缓冲区在64位上溢出?

这两条指令完全按照您的期望执行。您已经使用覆盖了之前的堆栈框架,

0x41
因此当您点击时
leaveq
,您将执行以下操作:

mov rsp, rbppop rpb

现在

rsp
指向
rbp
以前的操作。但是,您已经覆盖了该内存区域,因此当您执行时
pop rbp
,硬件实际上就是在这样做

mov rbp, [rsp]add rsp,1

但是

[rsp]
现在有了
0x41
。因此,这就是为什么您看到
rbp
被该值填充的原因。

至于为什么

rip
没有像您期望的那样进行设置,那是因为
ret
将设置
rip
0x41
,然后在指令提取时生成异常(页面错误)。在这种情况下,我不会依靠GDB来显示正确的内容。您应该尝试使用程序文本段中的有效地址覆盖返回值,并且您可能不会看到这种奇怪的行为。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/408960.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号