繁体   English   中英

execve shellcode linux 分段错误

[英]execve shellcode linux segmentation fault

我试图运行这个shellcode,但它抛出了我:“分段错误”错误shellcode如下:

shellcode.asm:

global _start
_start:

jmp short ca
doit:
pop ebx
xor eax, eax
cdq
mov byte [ebx+7], al
mov long [ebx+8], ebx
mov long [ebx+12], eax
lea ecx, [ebx+8]
mov byte al, 0x0b

int 0x80
ca:
call doit
db '/bin/sh'

我用:'nasm -f elf shellcode.asm' 编译它并将它链接到:' ld -m elf_i386 -s -o shellcode shellcode.o

我认为错误是当我使用 mov [ebx+x], al/eax/ebx 因为当我从代码中删除它时没有错误

谢谢

您的问题是默认情况下.text部分不可写。 最简单的方法是将您的代码放入标记为可写的新自定义部分。 在 asm 文件的顶部添加这一行:

section .shellcode  progbits alloc exec write align=16

您还可以将-N开关传递给链接器。

或者,您可以重写 shellcode,以便它使用堆栈来创建参数。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM