Cyber security

SharpKiller – A Deep Dive Into Bypassing AMSI For Enhanced PowerShell Capabilities

Explore the cutting-edge world of PowerShell evasion with ‘SharpKiller.’

In this deep dive, we unravel the inner workings of this tool, designed to bypass AMSI (Antimalware Scan Interface) in real-time, allowing for seamless execution of PowerShell scripts that were once restricted.

Discover how ‘SharpKiller’ empowers security professionals and penetration testers by enhancing their PowerShell capabilities and outsmarting detection mechanisms. Lifetime AMSI bypass AMSI-Killer by @ZeroMemoryEx ported to .NET Framework 4.8.

Newly integrated features:

[ x ] – Live scan for new powershell processes every 0.5 seconds -> Automatically patches new powershell instances

Building The Solution

  • Set your platform explicitly to x64 in Build > configuration manager

How Does It Work?

Opcode Scan

  • we get the exact address of the jump instruction by searching for the first byte of each instruction this technique is effective even in the face of updates or modifications to the target data set.
  • for example : | 48:85D2 | test rdx, rdx | | 74 3F | je amsi.7FFAE957C694 | | 48 : 85C9 | test rcx, rcx | | 74 3A | je amsi.7FFAE957C694 | | 48 : 8379 08 00 | cmp qword ptr ds : [rcx + 8] , 0 | | 74 33 | je amsi.7FFAE957C694 |
  • the search pattern will be like this :{ 0x48,'?','?', 0x74,'?',0x48,'?' ,'?' ,0x74,'?' ,0x48,'?' ,'?' ,'?' ,'?',0x74,0x33}

Patch

Before Patch

  • The program tests the value of RDX against itself. If the comparison evaluates to 0, the program executes a jump to return. Otherwise, the program proceeds to evaluate the next instruction
  • we cant execute “Invoke-Mimikatz”

After Patch

  • we patch the first byte and change it from JE to JMP so it return directly
  • now we can execute “Invoke-Mimikatz”

Newly Created Processes

  • Sharp-Killer will patch any newly created Powershell processes in near real time.
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

Pystinger : Bypass Firewall For Traffic Forwarding Using Webshell

Pystinger is a Python-based tool that enables SOCKS4 proxying and port mapping through webshells. It…

1 week ago

CVE-Search : A Tool To Perform Local Searches For Known Vulnerabilities

Introduction When it comes to cybersecurity, speed and privacy are critical. Public vulnerability databases like…

1 week ago

CVE-Search : A Tool To Perform Local Searches For Known Vulnerabilities

Introduction When it comes to cybersecurity, speed and privacy are critical. Public vulnerability databases like…

1 week ago

How to Bash Append to File: A Simple Guide for Beginners

If you are working with Linux or writing bash scripts, one of the most common…

1 week ago

Mastering the Bash Case Statement with Simple Examples

What is a bash case statement? A bash case statement is a way to control…

1 week ago

How to Check if a File Exists in Bash – Simply Explained

Why Do We Check Files in Bash? When writing a Bash script, you often work…

1 week ago