inhumanoid
October 10th, 1999, 10:10 AM
Does anybody know how to kill a running process ??
|
Click to See Complete Forum and Search --> : Killing a process inhumanoid October 10th, 1999, 10:10 AM Does anybody know how to kill a running process ?? Lothar Haensler October 11th, 1999, 01:40 AM use the TerminateProcess API. inhumanoid October 11th, 1999, 09:59 AM How would I implement that ??? Can you give me an example.... Lothar Haensler October 11th, 1999, 10:03 AM the hard part is getting the process handle. Let's say you called CreateProcess to start a process. you would then call OpenProcess with the following params: hProcess = OpenProcess(SYNCHRONIZE OR PROCESS_TERMINATE, 0, pi.dwProcessId) (get all the constant declarations from the APIViewer add-in) (pi is the process_information structure that is filled by CreatProcess.) Now, you are ready to kill the process by means of: TerminateProcess( hProcess, 0) Be sure to check all return codes of all api calls. inhumanoid October 11th, 1999, 01:18 PM But what if the process was not started with CreateProcess ?? Lothar Haensler October 12th, 1999, 01:41 AM AFAIK the Shell function returns a Process ID (although the Documentation talks about a "task id"). You can get the Process handle from the Process id via OpenProcess API inhumanoid October 12th, 1999, 05:23 AM The thing is. I would like to have vb-source of the following: a list wich shows the path's of running processes (dll's exe's etc.) The option to select and kill any of these processes.. The thing is I did find source of apps revealing processes and various source with wich you could kill processes (usually the process needs to have a window (titlebar), wich is not what we are looking for here), but never a combination of the two... inhumanoid October 12th, 1999, 03:23 PM Could you explain it to me in an example.. Let's say f.i. c:\windows\notepad.exe is running.. How do I find it and then kill it....(winthout using the caption from the titlebar or anything) hburtin February 19th, 2001, 09:34 AM using psapi, this function list all process, check name and if the boolean is true check the filename too (use the longname (if>8 char) without the .exe), then for your sample just call GetProcessIDByName(L"notepad", true); to find it. #include <Psapi.h> DWORD GetProcessIDByName(LPWSTR szName, bool bCheckFileName) { DWORD aProcesses[1024], cbNeeded, cProcesses; unsigned int i; if ( !EnumProcesses( aProcesses, sizeof(aProcesses), &cbNeeded ) ) return 0; long l = wcslen(szName); WCHAR szProcessToFind[MAX_PATH]; wcscpy(szProcessToFind, szName); if(wcsicmp(&szName[l-4], L".exe")) { wcscat(szProcessToFind, L".exe"); } // Calculate how many process identifiers were returned. cProcesses = cbNeeded / sizeof(DWORD); // Print the name and process identifier for each process. for ( i = 0; i < cProcesses; i++ ) { WCHAR szProcessName[MAX_PATH] = L"unknown"; // Get a handle to the process. HANDLE hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, aProcesses[i]); // Get the process name. if(hProcess) { HMODULE hMod; DWORD cbNeeded; if(EnumProcessModules(hProcess, &hMod, sizeof(hMod), &cbNeeded)) { GetModuleBaseNameW(hProcess, hMod, szProcessName, sizeof(szProcessName)); if(wcsicmp(szProcessToFind, szProcessName) == 0) { CloseHandle( hProcess ); return aProcesses[i]; } else if(bCheckFileName) { WCHAR *p, szFileName[MAX_PATH] = L"unknown", szLongFileName[MAX_PATH] = L"unknown"; GetModuleFileNameExW(hProcess, hMod, szFileName, sizeof(szFileName)); p = wcsrchr(szFileName, '\\'); if(wcsicmp(szProcessToFind, p+1) == 0) { CloseHandle( hProcess ); return aProcesses[i]; } if(wcschr(szFileName, '~')) { if(GetLongPathNameW(szFileName, szLongFileName, sizeof(szLongFileName))) { p = wcsrchr(szLongFileName, '\\'); if(wcsicmp(szProcessToFind, p+1) == 0) { CloseHandle( hProcess ); return aProcesses[i]; } } } } } } CloseHandle(hProcess); } return 0; } hburtin February 19th, 2001, 09:39 AM [ ... i ... ] make my code italic... when you read aProcesses, you should add the index i : aProcesses [ i ] ccode is not enough ... codeguru.com
Copyright Internet.com Inc., All Rights Reserved. |