缓冲区溢出漏洞

贴一小段自己写的小程序

//MS VC++ 6.0 Console            lhj
#include <windows.h>

void main()
{
 //保留原来的返回地址
 DWORD *pBackAddress = (DWORD *)&pBackAddress + 2;
 DWORD BackAddress = *pBackAddress;

 //获取自己的执行代码地址
 HMODULE hModule = LoadLibrary("User32.dll");
 DWORD Address = (DWORD)GetProcAddress(hModule, "MessageBoxA");

 //缓冲区溢出
 DWORD Buffer[100];
 Buffer[0] = 0x5050C033;      // xor eax, eax   push  eax   push  eax
 Buffer[1] = 0xE8905050;      // push eax     push eax
 Buffer[2] = Address - (DWORD)&Buffer[3];     // call  MessageBoxA
 Buffer[3] = 0xE9909090;                                     // jmp  BackAddress
 Buffer[4] = BackAddress - (DWORD)&Buffer[5];

 //更改返回地址
 *pBackAddress = (DWORD)Buffer;

 

举例:

void MyRecv(char buffer)
{
 char TempBuf[1024];
 memset(TempBuf, 0, 1024);
 int len = recv(TempBuf);
 memcpy(buffer, TempBuf, len);
}

如果在我们的程序中调用过这样一段程序, 那么我们的程序将面临着溢出的危险!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值