缓冲区溢出实践

本文通过实操演示在Kali2.0环境中编译并运行C语言代码,遇到的段错误问题,并通过反编译揭示原因。作者对源代码进行修改,成功解决了问题,最终实现预期功能。

看到  http://www.cnblogs.com/bluesea147/archive/2012/05/19/2508208.html   的试验,自己动手试一试。

在kali 2.0中:

root@kali:~# vim test.c

#include <stdio.h>

void foo() {
    int a, *p;
    p = (int*)((int)&a + 8);
    *p += 13;
}

int main() {
    foo();
    printf("First printf call\n");
    printf("Second printf call\n");
    return 0;
}

编译并运行:

root@kali:~# gcc main.c -g
root@kali:~# ./a.out
First printf call
Second printf call
Segmentation fault

得到的结果和参考文章不同。肯定是由于环境不同,所以需要对源代码进行一定的修改。

反编译:

root@kali:~# objdump a.out -d

得到部分汇编代码如下:

调用foo()函数后的下一地址是0x8048420,而进入调用第二次prinf()函数的地址是0x804842d,两者相差13,所以源代码中应该是

  *p += 13;

foo()函数部分的汇编代码为

借用下原文的图像,这就是栈,%ebp指向系统栈最上面一个栈帧的底部。

从汇编代码可以看出,我的程序和原文中不同的地方在于,我的a是存在%ebp-8的地方,即Local Variable 2,因此a所在地址与Return Address间的距离为12。

源代码应修改为:

     p = (int*)((int)&a + 12);

至此应该没问题了,重新编译,运行:

BINGO!!!

转载于:https://www.cnblogs.com/justforfun12/p/5222829.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值