PE头部IMAGE_NT_HEADERS

PE头部IMAGE_NT_HEADERS是Win32程序装载的关键,包括PE标识符、文件头和可选头。32位结构体中,Signature定义PE标识符,接着是20字节的IMAGE_FILE_HEADER,然后是IMAGE_SECTION_HEADER详细说明节区。
摘要由CSDN通过智能技术生成

PE头部是真正用来装载Win32程序的头部,PE头的定义为IMAGE_NT_HEADERS,该结构体包含PE标识符、文件头与可选头这三部分。

该头部具有32位和64位之分。

32位的PE文件格式,IMAGE_NT_HEADERS32定义如下:

typedef struct _IMAGE_NT_HEADERS {       
	DWORD Signature;                              //位置在e_lfanew上
	IMAGE_FILE_HEADER FileHeader;				  //e_lfanew + 0x4         文件头结构体
	IMAGE_OPTIONAL_HEADER32 OptionalHeader;       //e_lfanew + 0x18        可选头结构体
} IMAGE_NT_HEADERS32, *PIMAGE_NT_HEADERS32;

该结构体中的Signature就是PE标识符,该部分占四个字节,在Winnt.h头文件中的宏定义为:

#define IMAGE_NT_SIGNATURE 0x50450000 // PE00

在PE头中,除了IMAGE_NT_HEADERS 以外,还有两个重要的结构体,分别是IMAGE_FILE_HEADER(文件头) 和 IMAGE_OPTIONAL_HEADER32(可选头)。


IMAGE_FILE_HEADER(文件头)

该结构体是IMAGE_NT_HEADERS中的第一个结构体,该结构体紧接在PE标识符的后面。该结构体大小为20个字节。

typedef struct _IMAGE_FILE_HEADER {
	WORD Machine;					//位置为 e_lfanew + 0x4 //该字段表示可执行文件的目标CPU类型
	WORD NumberOfSections;			//e_lfanew + 0x6		//
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值