Kein Zugriff auf Prozess für PROCESS_QUERY_INFORMATION
Hallo,
Ich durchlaufe gerade alle Prozesse per CreateToolhelp32Snapshot. Nun habe ich versucht den Dateinamen der Prozesse mit GetModuleBaseName herauszufinden. Dafür brauche ich erst mal ein Prozesshandle was ich mir per OpenProcess + PROCESS_QUERY_INFORMATION holen wollte. Interessanterweise bekomme ich auf diese weiße nicht EIN EINZIGES Handle. Mit PROCESS_ALL_ACCESS bekomme ich Zugriff auf die meisten (Nicht-System-)Prozesse was mir ausreicht. Da es so klappt habe ich grundlegend keinen Grund mich zu beschweren, aber aus welchem Grund erhalte ich eher ein Handle mit PROCESS_ALL_ACCESS als eins mit PROCESS_QUERY_INFORMATION? Kann man mit irgendeiner API die Weltherrschaft übernehmen sobald man ein PROCESS_QUERY_INFORMATION-Handle besitzt oder was? :mrgreen: Verstehe den Sinn/Grund dahinter nicht. Falls mich da jemand aufklären könnte wäre das super :) |
AW: Kein Zugriff auf Prozess für PROCESS_QUERY_INFORMATION
Schlägt wirklich OpenProcess fehl, oder ist es eher GetModuleBaseName? Die meisten APIs, die PROCESS_QUERY_INFORMATION brauchen, benötigen zusätzlich PROCESS_VM_READ (+ evtl. noch PROCESS_VM_OPERATION).
|
AW: Kein Zugriff auf Prozess für PROCESS_QUERY_INFORMATION
Fehlt da vielleicht das Flag PROCESS_VM_READ? Diese Funktion tut soweit ich das noch richtig in Erinnerung habe:
Delphi-Quellcode:
MfG Dalai
function GetPathFromPid(const APid: DWORD): string;
var hProc: THandle; Lpath: array[0..MAX_PATH-1] of Char; begin Result:= ''; hProc:= OpenProcess(PROCESS_QUERY_INFORMATION or PROCESS_VM_READ, false, APid); if (hProc <> 0) then try if GetModuleFileNameEx(hProc, 0, Lpath, MAX_PATH) > 0 then begin Result:= String(Lpath); end; finally CloseHandle(hProc); end; end; |
AW: Kein Zugriff auf Prozess für PROCESS_QUERY_INFORMATION
Zitat:
Zitat:
|
AW: Kein Zugriff auf Prozess für PROCESS_QUERY_INFORMATION
Okay mit PROCESS_VM_READ zusätzlich funktioniert es auch.
Und es lag tatsächlich nicht an OpenProcess. Die ersten paar die ich debuggt hatte waren alles Systemprozesse von denen ich sowieso Handle bekommen habe. Danke an alle ;) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:31 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz