Reflective Polymorphism Documentation¶
This project provides various utilities for the self-modification of PE images with the intention that they can be incorporated into external projects.
The source code is available on the GitHub homepage.
Contents:
Overview¶
The Reflective Polymorphism projects is currently composed of the following two
components each of which are contained within their respective .c
/ .h
files and are capable of operating independently.
- ReflectiveTransformer
- Functionality to transform PE files between DLL and EXE formats.
- ReflectiveUnloader
- Functionality to copy a loaded PE image out of memory and reconstruct a byte for byte copy of the PE image as it would exist on disk.
Proof of Concept¶
The proof of concept included in the project is the Main.c
file. This can be
compiled into a ReflectivePolymorphism.dll
which is compatible with
Reflective DLL Injection. The resulting executable can then be injected into
an arbitrary process (assuming premissions and architecture constraints are met)
with the inject.exe utility. Take note of the hash of the DLL file before
proceeding. See the releases page for pre-built binaries.
Once the DLL is injected into a process, it will display a message box. This is used to present the user with an opportunity to delete the original PE file from disk. After the message box is closed, the following two new files will be created on the user’s desktop.
- ReflectivePolymorphism.dll
- This is an identical copy of the injected DLL.
- ReflectivePolymorphism.exe
- This is an EXE version of the original, injected DLL.
The user can then compare the hashes of the two DLL files to determine that they are identical. At that point the user can delete the DLLs and run the EXE version which will create the DLL version again at the same path.