A windows dll injection library written in Rust.
| Injector Process | Target Process | Supported? |
| ---------------- | -------------- | ------------------------------------------ |
| 32-bit | 32-bit | Yes |
| 32-bit | 64-bit | No |
| 64-bit | 32-bit | Yes (requires feature into_x86_from_x64
) |
| 64-bit | 64-bit | Yes |
The example below will inject and then eject the module at the path "injection_payload.dll" into the process called "ExampleProcess".
```rust norun use dllsyringe::{Syringe, Process};
// find target process by name let targetprocess = Process::findfirstbyname("ExampleProcess").unwrap();
// create a new syringe for the target process let mut syringe = Syringe::forprocess(&targetprocess);
// inject the payload into the target process let injectedpayload = syringe.inject("injectionpayload.dll").unwrap();
// do something else
// eject the payload from the target (optional) syringe.eject(injected_payload).unwrap(); ```
The example below will perform the same injection as above, but will call the add
function defined exported from the injected module.
The definition of the exported add
function looks like this.
```rust no_run
extern "system" fn add(numbers: const (f64, f64), result: *mut f64) { unsafe { *result = (numbers).0 + (*numbers).1 } } ```
The code of the injector/caller will look like this. ```rust norun use dllsyringe::{Syringe, Process};
// find target process by name let targetprocess = Process::findfirstbyname("ExampleProcess").unwrap();
// create a new syringe for the target process let mut syringe = Syringe::forprocess(&targetprocess);
// inject the payload into the target process let injectedpayload = syringe.inject("injectionpayload.dll").unwrap();
let result: f64 = syringe.getprocedure(injectedpayload, "add").unwrap().unwrap().call(&(2f64, 4f64)).unwrap(); println!("{}", result); // prints 6
// eject the payload from the target (optional) syringe.eject(injected_payload).unwrap(); ```
Note that currently only functions with a signature of extern "system" fn(args: *mut A, result: *mut B) -> ()
are supported. When the payload and the procedure are compiled for a different target architecture the passed types have to have the same size.
Licensed under MIT license (LICENSE or http://opensource.org/licenses/MIT)
Inspired by Reloaded.Injector from Sewer.