Skip to content

Latest commit

 

History

History
57 lines (41 loc) · 2.46 KB

README.md

File metadata and controls

57 lines (41 loc) · 2.46 KB

Dll Injector v1.0


Goals

The goal of this project is to use various dll injection methods to inject a dll into an existing process's memory. This project also comes with a GUI, making it simple to select the dll you wish to inject and the target process.


Injection Methods

  • Traditional dll injection

    • VirtualAllocEx()

    Allocate memory for the path to the dll we wish to inject. Make sure to flag the allocated pages as readable, executable, and writeable!

    • WriteProcessMemory()

    Write the path to the dll to the allocated memory pointed to via the base address returned from VirtualAllocEx().

    • RtlCreateUserThread()

    A wrapper for NtCreateThreadEx which creates a new thread to execute the executable memory that we just wrote. This is from an undocumented API from ntdll.dll and is more likely to work than CreateRemoteThread() due to Microsoft making continuous tweaks to their documented APIs. The magic happens when the thread calls LoadLibraryA() and we pass our path (in the victim process's memory) as an argument to make the victim process load DllMain().

    • NtCreateThreadEx()

    The lowest API level for creating a thread.

    • VirtualFreeEx()

    Free the allocated memory from the dll path we wrote

    • FreeLibrary()

    Free the dll once the thread exits so that we can inject our dll again and make it call DllMain()


Compatibility

This project was built with MSVC 2015. It is notable that the GUI was written in C# .NET. The rest of the project is written in C/C++ with Win32Api.


Build and Usage

Set the project's configuration settings to Release for GUI, MessageBox, and NativeInjector in Visual Studio.

You can load any dll into any desired process. For quick testing, you can demo the MessageBox.dll packaged in this project's Release/bin.

To use the application, just run GUI.exe from the Release directory.


Resources


Contact

If you have any questions, send an email to [email protected]


License

Licensed under an Apache V2.0 license. For more details, see LICENSE.txt