PE结构-节

本文详细介绍了PE文件中节的概念,包括节表和节区,以及如何描述文件数据在内存中的搬运。讨论了节表的字段,如文件块首地址、大小、内存首地址和内存块大小。通过实例解析了节的二进制内容,并模拟了添加新节的过程,强调了头部扩充和内存对齐的影响,以及添加节的四个关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先,节的话有两部分,一部分是节表,另外一部分就是节区了,节表是用于描述节区信息的,而节区呢,简单点说就是数据块。

在上一篇博客中有提及过如何定位节表,重点就是需要根据选项头的大小来定位,这里的话就直接上一点代码吧,前两篇概念较多

    PIMAGE_DOS_HEADER pDosHeader = GetDosHeader(); //获取dos头
    if (pDosHeader == NULL)
        return NULL;
    PIMAGE_FILE_HEADER pFileHeader = GetFileHeader(); //获取文件头
    if (pFileHeader == NULL)
        return NULL;
    //这里为 sizeof Signature + sizeof IMAGE_FILE_HEADER 的大小
    DWORD offset = (DWORD)&(((PIMAGE_NT_HEADERS)0)->OptionalHeader);
    //首地址 + e_lfanew + offset + SizeOfOptionalHeader
    PIMAGE_SECTION_HEADER section = (PIMAGE_SECTION_HEADER)(GetPeAddrBase() + pDosHeader->e_lfanew
                                        + offset + pFileHeader->SizeOfOptionalHeader);

OK,老规矩下面来探讨一下节表的字段,把PE宏观看成一块一块的数据,那么在创建进程时,操作系统需要将此可执行文件按某种方式搬运过去&#x

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值