>백엔드 개발 >C++ >C에서 이름으로 프로세스 핸들을 얻는 방법은 무엇입니까?

C에서 이름으로 프로세스 핸들을 얻는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-24 05:40:09699검색

How to Get a Process Handle in C   by its Name?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.