identyfikacja lokalizacji na dysku programu po jego procesie

0

W jaki sposób można zidentyfikować lokalizację na dysku jakiegoś programu za pomocą jego procesu w systemie? Dajmy na to odpalam Menedżer zadań windows, wybieram procesy i widzę proces o nazwie "gg.exe"

Czy jest możliwość, aby z pomocą delphi sprawdzić, z jakiej lokalizacji proces "gg.exe" został włączony, aby zwrócona mi została lokalizacja tego programu np. 'C:\program files\gadu-gadu\gg.exe" ??

0

Oto kodzik:

uses
Psapi, tlhelp32;
procedure CreateWin9xProcessList(List: TstringList);
var
  hSnapShot: THandle;
  ProcInfo: TProcessEntry32;
begin
  if List = nil then Exit;
  hSnapShot := CreateToolHelp32Snapshot(TH32CS_SNAPPROCESS, 0);
  if (hSnapShot <> THandle(-1)) then
  begin
    ProcInfo.dwSize := SizeOf(ProcInfo);
    if (Process32First(hSnapshot, ProcInfo)) then
    begin
      List.Add(ProcInfo.szExeFile);
      while (Process32Next(hSnapShot, ProcInfo)) do
        List.Add(ProcInfo.szExeFile);
    end;
    CloseHandle(hSnapShot);
  end;
end;

procedure CreateWinNTProcessList(List: TstringList);
var
  PIDArray: array [0..1023] of DWORD;
  cb: DWORD;
  I: Integer;
  ProcCount: Integer;
  hMod: HMODULE;
  hProcess: THandle;
  ModuleName: array [0..300] of Char;
begin
  if List = nil then Exit;
  EnumProcesses(@PIDArray, SizeOf(PIDArray), cb);
  ProcCount := cb div SizeOf(DWORD);
  for I := 0 to ProcCount - 1 do
  begin
    hProcess := OpenProcess(PROCESS_QUERY_INFORMATION or
      PROCESS_VM_READ,
      False,
      PIDArray[I]);
    if (hProcess <> 0) then
    begin
      EnumProcessModules(hProcess, @hMod, SizeOf(hMod), cb);
      GetModuleFilenameEx(hProcess, hMod, ModuleName, SizeOf(ModuleName));
      List.Add(ModuleName);
      CloseHandle(hProcess);
    end;
  end;
end;

procedure GetProcessList(var List: TstringList);
var
  ovi: TOSVersionInfo;
begin
  if List = nil then Exit;
  ovi.dwOSVersionInfoSize := SizeOf(TOSVersionInfo);
  GetVersionEx(ovi);
  case ovi.dwPlatformId of
    VER_PLATFORM_WIN32_WINDOWS: CreateWin9xProcessList(List);
    VER_PLATFORM_WIN32_NT: CreateWinNTProcessList(List);
  end
end;

Wywołujesz funkcję np poprzez:

var
  ss:Tstringlist;
begin
  ss:=Tstringlist.create;
  GetProcessList(ss);
end;

W Stringliście "ss" masz wszystkie uruchomione procesy z systemu wraz z ich ścieżkami. Możesz sobie znaleŹć indeks pod którym jest "gg.exe"

1 użytkowników online, w tym zalogowanych: 0, gości: 1