[系统安全]PE文件头中的重定位表

PE加载的过程

任何一个EXE程序会被分配4GB的内存空间,用户层处理低2G的内存,驱动处理高2G的内存。

  • 1、双击EXE程序,操作系统开辟一个4GB的空间。
  • 2、从ImageBase决定了加载后的基址,ImageSize决定了程序有多大。
  • 3、然后加载DLL

大体流程:

1、PE被执行时,装载器为进程分配虚拟地址空间,在此情况下,并不是把完整的PE文件载入到磁盘中,而是做一个简单的内存映射。

2、PE装载器在内核中创建进程对象和主进程对象以及其他的内容。

3、PE装载器搜索输入表,装载应用程序所用的动态链接库,方式类似于应用程序的装载。

4、PE装载器执行PE文件首部所指定地址的代码,开始执行应用程序。

PE文件头中的重定位表

程序被装入内存时,其基址是由字段IMAGE_OPTIONAL_HEADER32.ImageBase决定的。如果当装载时该位置已经被别的程序使用,那么操作系统就有权重新选择一个基地址。这个时候就需要对所有的重定位信息进行修正,而修正的依据就是PE的重定位表。

重定位表结构

重定位表为数据目录中注册的数据类型之一,其描述信息处于数据目录的第6个目录项中。

typedef struct _IMAGE_BASE_RELOCATION {
    DWORD   VirtualAddress;    // 页存储的起始RVA
    DWORD   SizeOfBlock;      // 重定位块的长度
} IMAGE_BASE_RELOCATION;
typedef IMAGE_BASE_RELOCATION UNALIGNED * PIMAGE_BASE_RELOCATION;
相关推荐
黑客K-ing7 分钟前
网工考试——数据链路层、网络层、传输层
服务器·网络·php
DanceDonkey1 小时前
基于Socket实现Http类SSE效果
网络·网络协议·http
!!!5251 小时前
HTTP-响应协议
网络·网络协议·http
hgdlip2 小时前
ip属地出省会变吗?怎么出省让ip属地不变
服务器·网络·tcp/ip
硬件技术我知道2 小时前
用AMIDEDOS.EXE查看和编辑计算机个性化信息
网络·人工智能·嵌入式硬件·物联网·计算机视觉·硬件工程·智慧城市
HUODUNYUN2 小时前
移动应用安全:保护用户隐私与数据的关键解决方案
网络·安全·web安全·移动应用安全
vortex52 小时前
Web枚举:深入了解目标应用系统
前端·安全·网络安全
幸运的的飞起2 小时前
计算机简答题
服务器·网络·计算机网络
JZC_xiaozhong2 小时前
制造业该怎么做数据治理?
大数据·安全·ci/cd·容器·数据挖掘·数据分析·云计算
是Dream呀3 小时前
Python从0到100(八十三):神经网络-使用残差网络RESNET识别手写数字
网络·python·神经网络