导出表EAT


DLL

Dynamic Link Library(DLL),内存映射

Windows操作系统提供了数量庞大的库函数,包括进程、内存、窗口、消息、文件、网络等。同时运行多个程序时,每个进程都包含相同的库,严重浪费内存。

IMAGE_EXPORT_DIRECTORY

EAT是DLL的核心机制

  • 不同的程序可以调用库文件中提供的函数
  • 通过EAT,得到库文件导出函数的入口地址
    在这里插入图片描述
  1. Name:库文件名字符串地址
  2. NumberOfFunctions:实际Export函数的个数
  3. NumberOfNames:Export函数中具有名字的函数个数
  4. AddressOfFunctions:Export函数地址数组
  5. AddressOfNmaes:函数名称地址数组
  6. AddressOfNameOrdinals:Ordinals地址数组

在这里插入图片描述

GetProcAddress()操作原理

如何通过EAT获得函数地址?
从库中获得函数地址的API为GetProcAddress()函数。

  1. AddressOfNames定位“函数名称地址数组”
  2. 在“函数名称地址数组”中,通过比较字符串(strcmp),查找指定的函数名称。此时的数组索引称为name_index
  3. 利用AddressOfNameOridinals成员,定位ordinal数组
  4. ordinal数组中,通过name_index查找相应的ordinal
  5. 利用AddressOfFunctions成员,定位“函数地址数组”(EAT)
  6. 在函数地址数组中,利用ordinals值作为索引,获得指定函数的起始地址

如果函数是以序号导出的,那么查找的时候直接用序号减去Base,得到的值就是函数在AddressOfFunctions中的下标。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值