我有这个简单的代码测试代码:
#include <Windows.h>
#include <stdio.h>
/* Declare new sections to store encrypted code and shellcode data */
#pragma section(".code", execute, read, write)
#pragma comment(linker,"/SECTION:.code,ERW")
// From here executable code will go in .code section
#pragma code_seg(".code")
int test()
{
printf("prova");
return 0;
}
// .stub SECTION
#pragma section(".stub", execute, read, write)
#pragma code_seg(".stub")
int main(int argc, char *argv[]){
test(); /* Call function which executes shellcode now that it is decrypted */
return 0;
}
谁能告诉我为什么如果我转储这个文件我只得到这个默认部分:
- 。数据
- .rdata
- .reloc
- .rsrc
- 。存根
- 。文本
它没有生成的 .code 段。我想我曾经在一些以前的项目中这样做过,我做错了什么吗?
-- 进一步测试 --
- 转储
.obj
文件.code
部分显示。 .stub
显示倾销.exe
或.obj
- 删除
#pragma comment(linker,"/SECTION:.code,ERW")
不起作用 - 添加
#pragma comment(linker,"/SECTION:.stub,ERW")
并没有改变dumpbin结果.exe
,.stub
仍然显示 - 将名称从 更改
.code
为.somethingelse
也不起作用,结果相同