翻回以前写的HOOK 程序,发现之前的挂钩线程ID部分有问题。。于是网上找各种获取线程ID的方法,把找到的几种写下来方便以后用
1.通过进程映射名称获取主线程ID(进程映射名应为全大写,如谷歌浏览器的进程名:CHROME.EXE)
DWORD WINAPI GetThreadIDByName(LPCTSTR lpFilename)
{
DWORD dwThreadID = 0;
PROCESSENTRY32 pe32;
HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
if(hProcessSnap == INVALID_HANDLE_VALUE)
return 0;
if(!Process32First(hProcessSnap,&pe32))
{
do
{
_strupr(pe32.szExeFile);
if(!strcmp(pe32.szExeFile,lpFilename))
{
//遍历线程查找对应ID
HANDLE hThreadSnap = ::CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD,0);
THREADENTRY32 te32 = {sizeof(te32)};
if(::Thread32First(hThreadSnap,&te32))
{
do
{
if(te32.th32OwnerProcessID == pe32.th32ProcessID)
{
dwThreadID = te32.th32ThreadID;
break;
}
}
while(::Thread32Next(hThreadSnap,&te32));
}
CloseHandle(hThreadSnap);
break;
}
}