/Manager

Library of tools and examples for loading/bootstrapping managed code from unmanaged code in .NET

Primary LanguageC++MIT LicenseMIT

Manager

Toolset and Libraries for reflectively running/bootstrapping managed code from unmanaged code using the .NET Framework. There are three techniques represented here:

  1. CLRHosting: Load Assemblies using Microsoft's official Unmanaged CLR Hosting APIs.
  2. DemoAssembly: A demo EXE and DLL used for testing
  3. DemoLoad: A simple program for loading DLLs with LoadLibraryA. For testing DllMain and exported functions.
  4. MixedAssembly: Load Assemblies using C++/CLI, a version of C++ that can mix both unmanaged machine code and managed MSIL code on a per-module or even per-function basis.
  5. Shellcode: Various PICs or tools (some are just links) for injecting .NET Assemblies through native shellcode.

Additionally, the DemoAssembly project is provided that includes an Assembly that pops up a command prompt. This can be used as an easy test payload. It is provided in both DLL and EXE format.

The DemoLoad project is a simple program that loads a DLL through LoadLibrary. It is useful for testing a generated DLL payload.

Purpose

The capability to load managed code from unmanaged code can serve many purposes. However, from the perspective of a red-teamer, this represents the ability to inject .NET code into arbitrary Windows processes. It can also provide a more Op-Sec friendly way of crafting stagers for .NET Assemblies that does not rely upon putting easily reversable managed code onto disk.