■ ■ ■ ■ ■ ■
SearchAvailableExe/SearchAvailableExe.cpp
| skipped 108 lines |
109 | 109 | | exit(0); |
110 | 110 | | } |
111 | 111 | | |
| 112 | + | std::map<DWORD, bool> processIdMap; |
| 113 | + | BOOL CALLBACK lpEnumFunc(HWND hwnd, LPARAM lParam) { |
| 114 | + | DWORD processId; |
| 115 | + | GetWindowThreadProcessId(hwnd, &processId); |
| 116 | + | |
| 117 | + | CHAR windowText[256]; |
| 118 | + | GetWindowTextA(hwnd, windowText, ARRAYSIZE(windowText)); |
| 119 | + | |
| 120 | + | if (processIdMap[processId]) { |
| 121 | + | PostMessage(hwnd, WM_CLOSE, 0, 0); |
| 122 | + | } |
| 123 | + | |
| 124 | + | return TRUE; |
| 125 | + | } |
| 126 | + | |
| 127 | + | DWORD WINAPI MonitorThread(LPVOID lpParam) { |
| 128 | + | HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); |
| 129 | + | PROCESSENTRY32 process = { sizeof(PROCESSENTRY32) }; |
| 130 | + | |
| 131 | + | // 遍历进程 |
| 132 | + | while (Process32Next(hProcessSnap, &process)) { |
| 133 | + | if (strstr(wstring2string(process.szExeFile).c_str(), "csrss.exe")) |
| 134 | + | processIdMap[process.th32ProcessID] = true; |
| 135 | + | } |
| 136 | + | |
| 137 | + | while (1) |
| 138 | + | EnumWindows(lpEnumFunc, (LPARAM)&processIdMap); |
| 139 | + | |
| 140 | + | return 0; |
| 141 | + | } |
| 142 | + | |
112 | 143 | | int main(int argc, char* argv[]) { |
113 | 144 | | |
114 | 145 | | memset(&c, 0, sizeof(c)); |
| skipped 36 lines |
151 | 182 | | |
152 | 183 | | *output << "dll信息统计完毕,初步符合要求的白程序有:" << results.size() << "个" << endl; |
153 | 184 | | |
| 185 | + | HANDLE hThread = CreateThread(NULL, 0, MonitorThread, NULL, 0, NULL); |
| 186 | + | |
154 | 187 | | //运行目标程序,判断是否会加载hook的dll |
155 | 188 | | RunPE(); |
| 189 | + | |
| 190 | + | TerminateThread(hThread, 0); |
156 | 191 | | |
157 | 192 | | *output << "找到可利用白文件:" << results.size() << "个" << endl; |
158 | 193 | | |
| skipped 35 lines |