Skip to content

手动查找 IAT 并使用 ImportREC 重建

Warning

The current page still doesn't have a translation for this language.

You can read it through Google Translate.

Besides, you can also help to translate it: Contributing.

示例程序可以从此链接下载: manually_fix_iat.zip

我们常用的ImportREC脱壳是使用的软件自带的IAT auto search, 但是如果我们要手动查找IAT的地址并dump出来, 又该怎么操作呢?

首先使用ESP定律, 可以很快地跳转到OEP: 00401110.

1.png

我们右键点击, 选择查找->所有模块间的调用

2.png

显示出调用的函数列表, 我们双击其中的某个函数(注意这里要双击的应该是程序的函数而不是系统函数)

3.png

我们来到了函数调用处

4.png

右键点击跟随, 进入函数

5.png

然后再右键点击数据窗口中跟随->内存地址

6.png

这里因为显示是十六进制值, 不方便查看, 我们可以在数据窗口点击右键选择长型->地址, 就可以显示函数名

7.png

注意我们要向上翻到IAT表的起始位置, 可以看到最开始的函数地址是004050D8kernel.AddAtomA, 我们向下找到最后一个函数, 也就是user32.MessageBoxA函数, 计算一下整个IAT表的大小。在OD的最下方有显示块大小:0x7C, 所以我们整个IAT块大小就是0x7C

8.png

打开ImportREC, 选择我们正在调试的这个程序, 然后分别输入OEP:1110, RVA:50D8, SIZE:7C, 然后点击获取输入表

9.png

这里在输入表窗口中右键选择高级命令->选择代码块.

10.png

然后会弹出窗口, 选择完整转储, 保存为dump.exe文件

11.png

dump完成后, 选择转储到文件, 这里选择修复我们刚刚dump出的dump.exe, 得到一个dump\_.exe. 这时整个脱壳就完成了