PE文件结构 - 导入表结构

最近在复习PE文件结构,被导入表绕了一把,于是又仔细的分解了一把,整理下思路。

至于导入表的解析,这个很简单,我们要学的是把架构理解清楚,明白文件和内存镜像的区别。

首先我们来看一张图:

 

 

这是在文件中导入表的结构,IMAGE_DIRECTORY_ENTRY_IMPORT 中的 OriginalFirstThunk 指向一个INT表,而FirstThunk指向的是IAT表,IAT表中存的也是一个指向最终IMAGE_IMPORT_BY_NAME结构的RVA指针,也就是PIMAGE_THUNK_DATA。

 

下面我们来看看程序运行时的状态:

 

这个时候其他的没变,但是IAT表全部被系统替换成函数的实际地址,不再是指向IMAGE_IMPORT_BY_NAME结构。

我们来看看函数是怎么调用的:

 

call dword ptr ds:[00C8502Ch]

这个00C8502Ch是什么呢?

 

 

这个正好是IAT中的一个项,而这个项中的值已经被系统替换成 GetModuleHandleW的真实地址,call 这个直接跳到 kernel32.dll -> GetModuleHandleW 处,完成函数调用。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值