Understanding The PE Header
The PE header contains the information the OS requires to run the executable.
This information is very useful, as it can give us more information about the functionality of the malware and how the malware interacts with the OS.
Why is the PE header important ?
It contains all of the important and necessary information required by the OS to execute the executable.
It contains information that specifies where the executable needs to be loaded into memory.
It contains the libraries that the executable requires to be loaded (dll).
It contains information that specifies where the execution begins.
Structure
MZ Header / DOS Header
Defines the file as an executable binary
DOS Stub (Program cannot be run in DOS mode)
Prints a message when run in DOS (Exists for compatibility)
PE File Header (Signature)
Defines the executable as a PE
Image Optional Header
Stores important informtion about the executable: Like the subsystem and the entry point.
Sections Table
Instructions on how to load the executable into memory
Sections
Executable sections of code and data used by the executable
Sections
.code / .text
Executable code
.data
Stores Data (R/W)
.rdata
Stores Data (Read Only)
.idata
Stores The Import Table
.edata
Stores Export Data
.rsrc
Stores Resources (Strings, icons)
Last updated