【发布时间】:2021-01-22 15:21:16
【问题描述】:
#include<stdio.h>
#include<stdlib.h>
char code[] ="\x52\x56\x57\x50\xB8\x41\x00\x00\x00\x50\xB8\x01\x00\x00\x00\xBF\x01\x00\x00\x00\x48\x89\xE6\xBA\x01\x00\x00\x00\x0F\x05\x58\x58\x5F\x5E\x5A\xC3";
int main(){
void(*func)() = (void (*)())code;
(*func)();
return 0 ;
}
我这里有一个字符串,它存储一个二进制代码来打印一个字符('A'),我将它作为一个函数指针传递给 func ,而不是我尝试执行它。 输出:
$ ./test
Segmentation fault (core dumped)
这是汇编代码:
0: 52 push rdx
1: 56 push rsi
2: 57 push rdi
3: 50 push rax
4: b8 41 00 00 00 mov eax,0x41
9: 50 push rax
a: b8 01 00 00 00 mov eax,0x1
f: bf 01 00 00 00 mov edi,0x1
14: 48 89 e6 mov rsi,rsp
17: ba 01 00 00 00 mov edx,0x1
1c: 0f 05 syscall
1e: 58 pop rax
1f: 58 pop rax
20: 5f pop rdi
21: 5e pop rsi
22: 5a pop rdx
23: c3 ret
【问题讨论】:
-
数据默认不可执行
-
您可能没有该数据段的执行权限。
-
你可以试试
gcc -z execstack。 -
这是特定于操作系统的。对于 Linux,请参阅 syscalls(2),尤其是 mmap(2)、mprotect(2)、execve(2),另请参阅 pmap(1) 和 proc(5),当然还有 Advanced Linux Programming。
标签: c linux string assembly segmentation-fault