上一篇讲到PE load程序已经找到了PE文件头,PE文件头的定义如下所示:

IMAGE_NT_HEADERS STRUCT
Signature DWORD ? ;PE文件标识
FileHeader IMAGE_FILE_HEADER <>
OptionalHeader IMAGE_OPTIONAL_HEADER32 <>
IMAGE_NT_HEADERS ENDS

Signature为PE文件标识,其值始终为00004550h,查ASCII表可以知道45h代表字符E,50h代表字符P。紧接着PE文件标识的是IMAGE_FILE_HEADER结构,这是一个20个字节的结构,其定义如下:
![]()
IMAGE_FILE_HEADER STRUCT
Machine WORD ? ;运行平台
NumberOfSections WORD ? ; 文件的节数目
TimeDateStamp DWORD ? ; 文件创建日期和时间,它的数值是从
1969年12月31日下午4:00开始到创
建时间为止的总秒数
PointerToSymbolTable DWORD ? ; 指向符号表(用于调试)
NumberOfSymbols DWORD ? ; 符号表中的符号数量(用于调试)
SizeOfOptionalHeader WORD ? ;IMAGE_OPTIONAL_HEADER32
结构的长度
Characteristics WORD ? ; 文件属性
IMAGE_FILE_HEADER ENDS

各个字段的意义如注释所示,其中元素SizeOfOptionalHeader的值始终为e0h,表示可选头的大小,e0h换算成十进制表示224,即可选头的大小始终为224个字节。
本文深入讲解PE文件的内部结构,包括PE文件头、IMAGE_FILE_HEADER和IMAGE_OPTIONAL_HEADER32等关键部分,揭示了PE文件如何组织和存储信息。
2470

被折叠的 条评论
为什么被折叠?



