Pentesting Tools

NullGate : Advancing Evasion Techniques In Windows Exploitation

NullGate is a sophisticated project designed to leverage NTAPI functions using indirect syscalls, incorporating the FreshyCalls method with a novel approach to dynamic syscall number retrieval.

It also employs a unique technique to bypass Windows Defender’s memory scanning, making it a powerful tool for process injection.

Key Features Of NullGate

  • Indirect Syscalls: NullGate uses indirect syscalls to invoke NTAPI functions, providing a layer of obfuscation and complexity that can evade detection by security software.
  • Dynamic Syscall Number Retrieval: The project incorporates a method for dynamically retrieving syscall numbers, enhancing its ability to adapt to different environments.
  • Obfuscation Techniques: NullGate includes obfuscation methods such as FNV-1 hashing for function names, which are evaluated at compile-time, making it difficult for reverse engineers to identify the functions being called.
  • Encryption and Encoding: It supports XOR encryption/decryption with multibyte keys and base64 encoding/decoding for payloads or messages, further complicating detection efforts.
  • Shellcode Handling: The tool provides functions to convert hex strings to binary vectors, facilitating the use of shellcode generated by tools like Metasploit’s msfvenom.

NullGate is designed to be easily integrated into projects using CMake’s FetchContent feature. Here’s a basic example of how to include it in a CMakeLists.txt file:

textcmake_minimum_required(VERSION 3.25)
include(FetchContent)

FetchContent_Declare(nullgate
GIT_REPOSITORY https://github.com/0xsch1zo/NullGate
GIT_TAG 1.0.0
)

FetchContent_MakeAvailable(nullgate)

project(test)
add_executable(test main.cpp)
target_link_libraries(test PRIVATE nullgate)

Bypassing Windows Defender Memory Scanning

A significant feature of NullGate is its ability to bypass Windows Defender’s memory scanning. The traditional method involves setting page permissions to PAGE_NOACCESS before creating a thread and then resuming it after the scan.

However, NullGate improves upon this by initially writing junk data to the process memory, creating a suspended thread, and then writing the actual shellcode before resuming the thread.

This approach ensures that the memory is not accessible during the scan, effectively evading detection.

Building And Running NullGate

To build NullGate, use the following commands:

bashgit clone https://github.com/0xsch1zo/NullGate
cd NullGate
cmake . -B build -DNULLGATE_BUILD_SAMPLE=ON
cmake --build build/

The sample executable will be available at <build_dir>/_deps/nullgate-build/sample.exe, which can be used to inject shellcode into a process specified by its PID.

NullGate offers a modern and sophisticated approach to process injection and evasion techniques, making it a valuable tool for those interested in advanced Windows exploitation and evasion strategies.

Its ability to dynamically retrieve syscall numbers and bypass memory scanning makes it particularly effective against modern security solutions.

Varshini

Varshini is a Cyber Security expert in Threat Analysis, Vulnerability Assessment, and Research. Passionate about staying ahead of emerging Threats and Technologies.

Recent Posts

How EDR Killers Bypass Security Tools

Endpoint Detection and Response (EDR) solutions have become a cornerstone of modern cybersecurity, designed to…

1 day ago

AI-Generated Malware Campaign Scales Threats Through Vibe Coding Techniques

A large-scale malware campaign leveraging AI-assisted development techniques has been uncovered, revealing how attackers are…

1 day ago

How Does a Firewall Work Step by Step

How Does a Firewall Work Step by Step? What Is a Firewall and How Does…

1 day ago

Fake VPN Download Trap Can Steal Your Work Login in Minutes

People trying to securely connect to work are being tricked into doing the exact opposite.…

3 days ago

This Android Bug Can Crack Your Lock Screen in 60 Seconds

A newly disclosed Android vulnerability is making noise for a good reason. Researchers showed that…

6 days ago

How to Fix MyISAM Table Corruption in MySQL?

In MySQL Server 5.5 and earlier versions, the MyISAM was the default storage engine. So,…

1 week ago