1. 程式人生 > >通過程序名得到程序控制代碼(tlhelp的方法)(ring3)

通過程序名得到程序控制代碼(tlhelp的方法)(ring3)

這個是因為我在網上搜只搜到列舉控制代碼的感覺很不方便,所以寫下這個僅供參考

HANDLE sub2(WCHAR* processname)
{
PROCESSENTRY32 pe32 = { 0 };
// 在本程序中拍一個所有程序的快照
HANDLE hModuleSnap = ::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if (hModuleSnap == INVALID_HANDLE_VALUE)
return INVALID_HANDLE_VALUE;
// 遍歷快照中記錄的程序
pe32.dwSize = sizeof(PROCESSENTRY32);
if (Process32First(hModuleSnap, &pe32))
{
do
{
if (wcsstr(pe32.szExeFile, processname))
{
break;
}
} while (Process32Next(hModuleSnap, &pe32));
}
::CloseHandle(hModuleSnap);
if (pe32.th32ProcessID != 0)
{
return OpenProcess(PROCESS_ALL_ACCESS, FALSE, pe32.th32ProcessID);
}
return INVALID_HANDLE_VALUE;
}