一,可移植可执行文件格式(PE Portable Executable)
全称为PE-COFF(Portable Executable and Common Object File Format) 可移植可执行和通用对象文件格式。
主要用于Windows 环境。PE 是 COFF 的改进版。
一个典型的PE文件布局
Dos Stub 程序用于保持向后兼容,但其重要意义在于在逆向工程中指向一个PE头的偏移量。
从图中我们可以看出程序一开始会是DOS 头,但其用处不大。
从文件头开始向后偏移 0x3C 的位置,我们可以找到一个偏移量,这个偏移量可以告诉我们从文件头向后偏移多少是PE的头部。
PE文件头后便是COFF文件头。
COFF 文件头格式:
Machine (机器类型):2个字节,值几乎总是 0x8664(AMD 64) 或 0x14C(AI32)
Number of Section(区段数):指示文件有多少个区段。
Time Date Stamp:时间戳
Pointer to Symbol Table:指向CO