缓冲区溢出无法运行

3
我尝试了一种基础的缓冲区溢出攻击,我覆盖了栈上保存的EIP并跳转到指定的地址。这个地址指向一个包含我的shellcode的shell变量。
但是在gdb中,程序在nopslide的第一个nop处发生了段错误。
我使用以下命令启动程序:
gdb-peda$ r $(python -c 'print "A"*22 + "\x5f\xb8\xff\xff"')

我有这个追踪:

[----------------------------------registers-----------------------------------]
EAX: 0x1a 
EBX: 0xf7fc3ff4 --> 0x15dd7c 
ECX: 0xffffaf38 --> 0xf7fc44e0 --> 0xfbad2a84 
EDX: 0xf7fc5360 --> 0x0 
ESI: 0x0 
EDI: 0x0 
EBP: 0x41414141 ('AAAA')
ESP: 0xffffaf80 --> 0xffffb100 --> 0xc ('\x0c')
EIP: 0xffffb85f --> 0x90909090
EFLAGS: 0x10296 (carry PARITY ADJUST zero SIGN trap INTERRUPT direction overflow)
[-------------------------------------code-------------------------------------]
   0xffffb85c:  nop
   0xffffb85d:  nop
   0xffffb85e:  nop
=> 0xffffb85f:  nop
   0xffffb860:  nop
   0xffffb861:  nop
   0xffffb862:  nop
   0xffffb863:  nop
[------------------------------------stack-------------------------------------]
0000| 0xffffaf80 --> 0xffffb100 --> 0xc ('\x0c')
0004| 0xffffaf84 --> 0xf7fef060 (push   ebp)
0008| 0xffffaf88 --> 0x80484bb (<__libc_csu_init+11>:   add    ebx,0x1219)
0012| 0xffffaf8c --> 0xf7fc3ff4 --> 0x15dd7c 
0016| 0xffffaf90 --> 0x80484b0 (<__libc_csu_init>:  push   ebp)
0020| 0xffffaf94 --> 0x0 
0024| 0xffffaf98 --> 0xffffb018 --> 0x0 
0028| 0xffffaf9c --> 0xf7e7ce46 (<__libc_start_main+230>:   mov    DWORD PTR [esp],eax)
[------------------------------------------------------------------------------]
Legend: code, data, rodata, value
Stopped reason: SIGSEGV
0xffffb85f in ?? ()
gdb-peda$ x/i $eip
=> 0xffffb85f:  nop

我使用Debian Wheezy操作系统,gcc版本为gcc (Debian 4.7.2-4) 4.7.2,gdb版本为7.4.1-debian。

这个gcc版本有新的保护措施吗?还是其他的问题?

谢谢。 (对我的英语表示抱歉:)


我的回答有帮到您吗?如果有的话,能否通过点击旁边的按钮将其选择为“已接受的答案”,这样问题就会从未解决中移除。谢谢。 - emil
1个回答

1

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接