我试图运行此shellcode,但它使我抛出:“ Segmentation fault”错误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时,因为当我从代码y中删除它时,没有错误
谢谢
您的问题是该.text部分默认情况下不可写。最简单的方法是将您的代码放入标记为可写的新自定义部分。将此行添加到您的asm文件的顶部:
.text
section .shellcode progbits alloc exec write align=16
您也可以将-N开关传递给链接器。
-N
或者,您可以重写shellcode,以便它使用堆栈来创建参数。