gpt4 book ai didi

c++ - 向 PE 文件添加一个部分,将入口点更改为新部分并执行任何代码

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:46:22 27 4
gpt4 key购买 nike

我正在开发 PE 文件加壳器,我可以成功加密可执行文件的 .text 部分,更改其入口点并添加新部分。新添加的部分将负责解密 .text 部分,然后跳转到原始入口点。

现在,我想更进一步,在新部分中执行更多代码。我几乎可以做任何我想做的事,但如果我调用外部函数(例如 iostream 中的 cout),修改后的可执行文件将在尝试执行非法指令时崩溃.新部分中 stub 的反汇编如下所示:

.newsec:0042C020                 push    ebp
.newsec:0042C021 mov ebp, esp
.newsec:0042C023 push offset loc_40EB50
.newsec:0042C028 mov eax, ds:dword_40E0B0
.newsec:0042C02D push eax
.newsec:0042C02E call loc_41A350
.newsec:0042C033 add esp, 8
.newsec:0042C036 pop ebp
.newsec:0042C037 retn

地址 0x42c033 的行将跳转到 .text 部分,但那里的代码与 std::cout 应该做什么无关。

为了帮助你帮助我,新部分中添加的代码在文件 stub.h/cpp 中:

#pragma comment(linker, "/OPT:NOREF")
#pragma optimize( "", off )
#pragma section(".stub",read,write,execute)

__declspec(code_seg(".stub"))
void hello_test()
{
std::cout << "hello world";
}

__declspec(code_seg(".stub"))
void default_stub_start(void) {
__asm {
call hello_test

mov eax, 0x400000 //oep
jmp eax
}
}

然后,整个 .stub 部分将按原样复制到我添加到可执行文件的新部分中。编译运行顺利,但修改后的可执行文件会崩溃,正如我上面解释的那样。如果我删除行

std::cout << "hello world";

用一些基本的数学代替它,它工作得很好。

我的问题是:如何在不破坏可执行文件的情况下使用外部函数?

最佳答案

我忘记了这个问题,但实际上在问了几个月后找到了解决方案。这里的问题是必须手动链接到外部函数,因为一旦代码被解压到内存中,它们的地址在运行时是未知的。

为此,应执行以下操作:

  • 遍历进程环境 block 以迭代加载库的链表。
  • 找到库 kernel32.dll 并遍历其导出表,例如获取 GetProcAddress 和 LoadLibrary 的地址。
  • 使用之前解析的 API 加载和解析任何其他 API。

有关更多信息,请阅读“The Rootkit Arsenal”的第 10 章。

关于c++ - 向 PE 文件添加一个部分,将入口点更改为新部分并执行任何代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37565735/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com