C에서 이름으로 프로세스 검색 및 핸들 가져오기
많은 경우 프로세스 이름을 알고 핸들을 가져오는 것은 특정 프로세스를 제어하고 상호 작용하는 데 필수적입니다. 응용 프로그램을 실행 중입니다. 이는 그래픽 인터페이스가 부족하고 창 기반 기술을 사용하여 찾을 수 없는 프로세스를 처리할 때 더욱 중요해집니다. 이러한 시나리오에서는 이름으로 프로세스 핸들을 검색하는 기능을 통해 이러한 애플리케이션을 직접 조작하고 제어할 수 있습니다.
C에서 이를 수행하려면 다음 솔루션을 사용할 수 있습니다.
#include <cstdio> #include <windows.h> #include <tlhelp32.h> int main(int, char *[]) { PROCESSENTRY32 entry; entry.dwSize = sizeof(PROCESSENTRY32); HANDLE snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); if (Process32First(snapshot, &entry) == TRUE) { while (Process32Next(snapshot, &entry) == TRUE) { if (stricmp(entry.szExeFile, "target.exe") == 0) { HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, entry.th32ProcessID); // Do stuff... CloseHandle(hProcess); } } } CloseHandle(snapshot); return 0; }
이 코드는 실행 파일 이름이 지정된 프로세스의 핸들을 검색합니다. tlhelp32 라이브러리의 CreateToolhelp32Snapshot 및 Process32Next 함수를 활용하여 실행 중인 프로세스를 열거하고 검색합니다. 실행 파일 이름을 비교하여 대상 프로세스를 찾으면 OpenProcess를 사용하여 프로세스 핸들을 얻습니다.
그러나 PROCESS_ALL_ACCESS를 사용하여 프로세스에 액세스해야 하는 경우 액세스 거부 문제가 발생할 수 있습니다. 이 문제를 해결하려면 SeDebugPrivilege 권한을 활성화해야 하며, 이는 adjustTokenPrivileges API 호출을 통해 수행할 수 있습니다. 필요한 단계를 통합한 수정된 코드는 다음과 같습니다.
#include <cstdio> #include <windows.h> #include <tlhelp32.h> void EnableDebugPriv() { HANDLE hToken; LUID luid; TOKEN_PRIVILEGES tkp; OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken); LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &luid); tkp.PrivilegeCount = 1; tkp.Privileges[0].Luid = luid; tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED; AdjustTokenPrivileges(hToken, false, &tkp, sizeof(tkp), NULL, NULL); CloseHandle(hToken); } int main(int, char *[]) { EnableDebugPriv(); PROCESSENTRY32 entry; entry.dwSize = sizeof(PROCESSENTRY32); HANDLE snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, NULL); if (Process32First(snapshot, &entry) == TRUE) { while (Process32Next(snapshot, &entry) == TRUE) { if (stricmp(entry.szExeFile, "target.exe") == 0) { HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, entry.th32ProcessID); // Do stuff... CloseHandle(hProcess); } } } CloseHandle(snapshot); return 0; }
이러한 접근 방식을 통합하면 이름으로 프로세스 핸들을 효과적으로 검색하고 그래픽 인터페이스 없이도 프로세스를 조작할 수 있습니다.
위 내용은 C에서 이름으로 프로세스 핸들을 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!