文章目录
DOS头
WORD e_magic MZ标记.判断是否是可执行文件
DWORD e_flanew PE头相对于文件便宜,用于定位PE文件
标准PE头
WORD Machine 程序运行CPU型号.
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
TimeDateStamp 程序加壳需要 map文件.
map文件中描述了所有的函数信息. 每次加壳前需要校验 map文件生成时间和程序的生成之间一不一样
Characteristics 各个位的含义
将各个位上的值相加,等于 010F
可选PE头
WORD MAIGC 说明文件类型10B:32位下PE文件.20B:64位下PE文件
DWORD SizeOFCode 所有代码节的和.必须是 FileAlignment的整倍数.编译器填写的 没用
DWORD ImageBase 内存镜像基址
DWORD SectionAlignment 内存对齐
DWORD FIleALignment 文件对齐
DWORD SizeOFImage 内存中中个PE文件的映射尺寸.可以比实际值大.但必须是SectionAlignment的整倍数
DWORD SizeOFHeaders 所有节和拖按照文件对齐后的大小.严格按照SectionAlignment对齐.否则加载会出错
程序断点
程序在OD中运行. 自动停的地方:
是 ImageBase 的数据 + AddressOFEntryPoint 相加的结果
Basexxx
代码和数据的基址
ImageBase
内存镜像地址.
PELoader
这个名字很low. 换个名字就是 内核重载.
用于 调式具有反调试功能的软件
FileBuffer
将exe 从 硬盘上 COPY 到内存中
之后在通过一定格式拉伸.
他们之间主要是 FileBuffer 没有拉伸. 画红框的是拉伸之后的
拉伸之后,在内存中程序的起始运行地址是 ImageBase.
ImageBase开始存储的是: DOS头,PE头,标准PE头.
而这个值是什么,是ImageBase 存储的值决定的
AddressOFEntryPoint
OEP:真实物理地址
这个值可能存储在任一一个段中的任一位置
SizeOFImageBase
整个exe程序装载到内存之后被拉长了的长度.
SizeOFHeaders
所有节和头按照文件对齐后的大小