手写一个栈溢出程序(深入版)

上一篇文章里写到了一个C语言写的栈溢出程序,通过上一篇文档的内容,找到了溢出的位置,现在便在原来的基础上实现自己代码的写入,实现效果如下图:
在原来的基础上加入了一个字符串“Hello!”,并显示
载入OD,来到上一篇文章的溢出位置,如图所示:
关键注释

现在我们可以构造文本文档的内容,使其覆盖掉返回地址,覆盖成为我们需要的地址。
首先通过OD找到printf()函数的汇编调用方式,本机为call 00401470,
1.用OD找到一块空的内存区域,加入字符串Helloworld。
0042BFF0
2.用OD找到一块空的代码段加入如下代码,如图所示:
植入代码
记录植入代码的地址,00423FA0,构造key文件,使其覆盖掉返回值,
key文件构造,运行成功效果如图:
运行效果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值