P41PE头字段说明
1、DOC头:
WORD e_magic ** "MZ标记" 用于判断是否为可执行文件.
DWORD e_lfanew; ** PE头相对于文件的偏移,用于定位PE文件
2、标准PE头:
WORD Machine; ** 程序运行的CPU型号:0x0 任何处理器/0x14C 386及后续处理器
WORD NumberOfSections; ** 文件中存在的节的总数,如果要新增节或者合并节 就要修改这个值.
DWORD TimeDateStamp; * 时间戳:文件的创建时间(和操作系统的创建时间无关),编译器填写的.
DWORD PointerToSymbolTable;
DWORD NumberOfSymbols;
WORD SizeOfOptionalHeader; ** 可选PE头的大小,32位PE文件默认E0h 64位PE文件默认为F0h 大小可以自定义.
WORD Characteristics; * 每个位有不同的含义,可执行文件值为10F 即0 1 2 3 8位置1 节的属性,可读写等。
3、可选PE头:
WORD Magic; ** 说明文件类型:10B 32位下的PE文件 20B 64位下的PE文件
BYTE MajorLinkerVersion;
BYTE MinorLinkerVersion;
DWORD SizeOfCode;* 所有代码节的和,必须是FileAlignment的整数倍 编译器填的 没用
DWORD SizeOfInitializedData;* 已初始化数据大小的和,必须是FileAlignment的整数倍 编译器填的 没用
DWORD SizeOfUninitializedData;* 未初始化数据大小的和,必须是FileAlignment的整数倍 编译器填的 没用
DWORD AddressOfEntryPoint;** 程序入口
DWORD BaseOfCode;* 代码开始的基址,编译器填的 没用
DWORD BaseOfData;* 数据开始的基址,编译器填的 没用
DWORD ImageBase;** 内存镜像基址
DWORD SectionAlignment;** 内存对齐
DWORD FileAlignment;** 文件对齐
WORD MajorOperatingSystemVersion;
WORD MinorOperatingSystemVersion;
WORD MajorImageVersion;
WORD MinorImageVersion;
WORD MajorSubsystemVersion;
WORD MinorSubsystemVersion;
DWORD Win32VersionValue;
DWORD SizeOfImage;** 拉伸后的大小 内存中整个PE文件的映射的尺寸,可以比实际的值大,但必须是SectionAlignment的整数倍
DWORD SizeOfHeaders;** 所有头(DOS PE标记 标准PE 可选PE)+节表按照文件对齐后的大小,否则加载会出错
DWORD CheckSum;* PE中两字节的循环加 溢出不计 校验和,一些系统文件有要求.用来判断文件是否被修改.
WORD Subsystem;
WORD DllCharacteristics;
DWORD SizeOfStackReserve;* 初始化时保留的堆栈大小
DWORD SizeOfStackCommit;* 初始化时实际提交的大小
DWORD SizeOfHeapReserve;* 初始化时保留的堆大小
DWORD SizeOfHeapCommit;* 初始化时实践提交的大小
DWORD LoaderFlags;
DWORD NumberOfRvaAndSizes;* 目录项数目
内核重载: PEloader
FileBuffer(名字随便起的)跟在文件中的是一样的 就是将硬盘的值存到内存中 如果要想之跑起来 就得拉伸 (有点抽象
—>ImageBuffer镜像内存也叫文件映像 (对FileBuffer的拉伸,即PEloader)
ImageBase:程序加载的地址 预防被强占时还能继续运行 (4GB内存中 有2GB是用户的 有很多个pe结构 不仅仅是1个)
节表:内存中有多少节 就会对此n节进行说明 有多少节就有多少节表