免费注册 查看新帖 |

Chinaunix

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

求高手代码分析一段堆栈溢出代码 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-04-21 12:10 |只看该作者 |倒序浏览
最简单的堆栈溢出demo
参考了Nish Bhalla的堆栈溢出教程。要看到效果必须把VC编译选项 /GZ去掉。
---------
以下代码请高手详细解答一下,为什么会溢出?还有那句printf,为什么会在copy函数执行后才调用的呢?

  1. #include "stdafx.h"
  2. #include <string.h>
  3. #include <stdlib.h>

  4. int copy(char* input)
  5. {
  6.     char var[20];
  7.     strcpy (var, input);
  8.     return 0;
  9. }
  10. int hacked(void)
  11. {
  12.     printf("这里是堆栈溢出程序.看到我了吧.\n");
  13.     exit(0);
  14. }
  15. int main(int argc, char* argv[])
  16. {
  17.     char hackstr[] = "AAAABBBBCCCCDDDDEEEEFFFFGGGG";
  18.     int *eip = (int*)&hackstr[24];        //20->23是EBP
  19.     *eip = (int)hacked;

  20.     copy(hackstr);
  21.     return 0;
  22. }
复制代码

论坛徽章:
0
2 [报告]
发表于 2007-04-21 12:32 |只看该作者
你把你认为说出来,并给个理由、

论坛徽章:
0
3 [报告]
发表于 2007-04-21 12:43 |只看该作者
我认为hackstr[24] - [27]原来的GGGG被替换成hacked的地址值而已。其它很正常。
菜鸟见解还是flw2解答。谢谢

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
4 [报告]
发表于 2007-04-21 12:44 |只看该作者
堆栈堆栈,在进程中堆和栈是不一样的。

论坛徽章:
0
5 [报告]
发表于 2007-04-21 12:47 |只看该作者
溢出是溢出 main的栈,main返回的时候才会返回到你的地址

论坛徽章:
0
6 [报告]
发表于 2007-04-21 13:30 |只看该作者
高这些有个什么用?你出去工作后就知道这些屁都不是一个。
还不就是利用了strcpy不检查数组的长度,首先你栈里面是main的返回地址
然后是 char var[20];
strcpy (var, input);的时候超出了var[20];超出的部分正好是hacked的地址
一返回就执行了hacked了
建议别搞这些把数学和数据结构学好是真的

论坛徽章:
0
7 [报告]
发表于 2007-04-21 13:35 |只看该作者
to flw2:堆和栈的是有区别的,这我知道。但这段程序我依然没看懂。
溢出是溢出 main的栈,main返回的时候才会返回到你的地址

您能详细解析下么,那句代码溢出了?谢谢

论坛徽章:
0
8 [报告]
发表于 2007-04-21 14:06 |只看该作者
你的问题是什么?准确点说。然后从上面的帖子找答案吧
int *eip = (int*)&hackstr[24];      
这个是什么用的?

论坛徽章:
0
9 [报告]
发表于 2007-04-21 14:07 |只看该作者
原帖由 okyzx 于 2007-4-21 12:10 发表
最简单的堆栈溢出demo
参考了Nish Bhalla的堆栈溢出教程。要看到效果必须把VC编译选项 /GZ去掉。
---------
以下代码请高手详细解答一下,为什么会溢出?还有那句printf,为什么会在copy函数执行后才 ...


我很疑惑你的代码是否能达到你要求的效果。

我给一个栈的示意图你就知道为什么了。

  1. _______________
  2. |   arg n       |
  3. ---------------
  4. |               |
  5. |...............|
  6. ---------------
  7. |   arg 2       |
  8. ---------------
  9. |   arg 1       |
  10. ---------------
  11. |   return addr |
  12. ---------------  <----- above is caller's stack frame, below is callee's stack frame
  13. |   %ebp        |
  14. ---------------
  15. |  callee data  |
  16. |               |
  17. |               |
  18. ---------------
  19. |   %esp        |
  20. _______________
复制代码


这段代码的本意是var[20]的地址加8个字节就是copy函数的返回地址(参考上图)。strcpy由于不会检查长度,所以如果input指向的数组超过了var的长度,是有可能覆盖到copy函数的返回地址的。这个时候copy函数就会返回被覆盖的地址,就是程序中hacked函数的起始地址。

但基于2个理由我认为你的代码不能工作
1.现在编译分配栈的时候,会预留空间,所以从&var[20] 到函数的返回地址之间会有一段空隙,你用28个字节的数组(数组hackstr后跟了一个4字节用于覆盖的地址)不一定能覆盖到返回地址。
2.strcpy函数以'\0'作为结束拷贝的判断条件。你这里在hackstr数组后面加上了4个字节的返回地址,却没有多加一个'\0'作为结束符,很有可能strcpy发生segmentation fault(当然,这个不一定)。应该再加一句hackstr[28] = '\0'

[ 本帖最后由 zx_wing 于 2007-4-21 14:09 编辑 ]

论坛徽章:
0
10 [报告]
发表于 2007-04-21 14:08 |只看该作者
原帖由 epegasus 于 2007-4-21 13:30 发表
高这些有个什么用?你出去工作后就知道这些屁都不是一个。
还不就是利用了strcpy不检查数组的长度,首先你栈里面是main的返回地址
然后是 char var[20];
strcpy (var, input);的时候超出了var[20];超出的部分正 ...

这些还是有点用的,性质不一样。
如果这些没有用,那么就是纯理论有用了,学习c语言就没有什么用,学习linux也没有用,更不用说学习怎么使用vi了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP