PE头字段说明-41

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

所有节和头按照文件对齐后的大小

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值