免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3853 | 回复: 9
打印 上一主题 下一主题

溢出攻击eip寄存器覆盖问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-22 19:52 |只看该作者 |倒序浏览
     在自己的电脑上演示溢出攻.出现如下问题:
         gdb中测试覆盖eip。当输入的n个‘A’时可以eip显示为414141,差一个字节没覆盖。但当输入n+1个'A'时确显示是eip内容为函数调用返回ret语句地址的内容。
         求解~~~

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
2 [报告]
发表于 2011-12-22 20:06 |只看该作者
分别啥时候 p $eip 的?

论坛徽章:
0
3 [报告]
发表于 2011-12-22 20:14 |只看该作者
在gdb中i reg得到的eip的内容。是发生段错误后返回后的

论坛徽章:
0
4 [报告]
发表于 2011-12-22 20:16 |只看该作者
是在gdb中调试出错返回后i reg得到的eip信息

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
5 [报告]
发表于 2011-12-22 20:37 |只看该作者
第二次既然是正确的返回地址怎么会出错?

论坛徽章:
0
6 [报告]
发表于 2011-12-22 20:52 |只看该作者
所以我也很不解。这个是打印结果:
Program received signal SIGSEGV, Segmentation fault.
0x08048434 in main ()
(gdb) i reg
eax            0x0        0
ecx            0xbffff2a8        -1073745240
edx            0x28d360        2675552
ebx            0x28bff4        2670580
esp            0xbffff2ec        0xbffff2ec
ebp            0x41414141        0x41414141
esi            0x0        0
edi            0x0        0
eip            0x8048434        0x8048434 <main+64>
eflags         0x10296        [ PF AF SF IF RF ]
我disas main得到的是<main+64>是ret。
如果是第一种情况时结果会是 0x414141 in ?();

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
7 [报告]
发表于 2011-12-22 21:01 |只看该作者
本帖最后由 zylthinking 于 2011-12-22 21:02 编辑

这我也没办法解释了, 我倒知道有个栈破坏检测的东西, 但似乎也解释不通。
但看那个ret, 很显然是main 中 return 生成的; 倒不是 call 时那个返回地址

论坛徽章:
0
8 [报告]
发表于 2011-12-22 21:07 |只看该作者
#include <stdio.h>
#include <string.h>
额~看来要搁浅了。
不过有另外发现就是如果arr的长度定义为5时就只是显示段错误。但如果长度是10的话还会调出** stack smashing detected ***显示错误。
int main(int argc, char **argv)
{
        char arr[5];

        strcpy(arr, argv[1]);
        printf("arr: 0x%c\n", *arr);

        return(0);
}

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
9 [报告]
发表于 2011-12-22 22:14 |只看该作者
反汇编一下, 然后一步步跟, 总能得到解释的

论坛徽章:
0
10 [报告]
发表于 2011-12-24 00:53 |只看该作者
lz,您可以看看这
http://sunus.is-programmer.com/
我这个blog废弃之前最后一篇就是写个缓冲区溢出小实验。
gcc是有栈检测的东西,你或许编译的时候需要加参数取消栈检测之后再进行实验
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP