![]() |
Alle Rechner-Prozesse Anzeigen Lassen
Hallo liebe DP-Gemeinde,
gibt es eine Möglichkeit, "alle" auf einem Rechner laufende Prozesse, Programme in einem Delphi-Programm in einer Memo-Box auszugeben? Mit "alle" meine ich nicht nur die, die ich im Task-Manager auch einsehen kann, das Problem habe ich bereits mit euerer Hilfe gelöst, sondern wirklich alles. Mit freundlichen Grüßen Manfred Zenns |
Re: Alle Rechner-Prozesse Anzeigen Lassen
Was sind den alle Prozesse? Und welchen Code verwendest du bisher?
|
Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
Der Unterschied zwischen Prozeß und Programm ist mir auch nicht ganz klar, sicher ist nur, daß die Prozesse ein Übermenge bzw. die Programme eine Teilmenge jeweils des anderen sind. Es gab mal bei einer diesbezüglichen Gegenfrage die Antwort, daß das, was der Taskmanager als Programme angibt, eben Programme, und was er in seiner Prozeßliste anzeigt, die Prozesse sind. Ob das allerdings objektiv ist oder nach welchen Kriterien der Taskmanager die Prozesse in Programme und Nichtprogramme („Unprogramme“) unterteilt, ist mir leider auch nicht bekannt. |
Re: Alle Rechner-Prozesse Anzeigen Lassen
Hallo und Danke für die schnellen Antworten...
@ Luckie Zitat:
Delphi-Quellcode:
und hier rufe ich die procedure auf:
procedure TProcess_Unit._updateProcess;
var tmpList : TStringList; {-} function ProcessList:TStringList; var PrIDs : array [0..1000] of DWORD; PrName : array [0..255] of Char; Bia : DWORD; i, PrCount : Integer; ProzessHandle : HWND; Modulhandle : HWND; {-} begin result:=TStringList.Create; //result.Add('<>'); if EnumProcesses(@PrIDs, SizeOf(PrIDs), bia) then begin if (Bia < sizeof(PrIDs)) then begin PrCount:=Bia div SizeOf(DWORD); for i:=0 to PrCount do begin ProzessHandle:=OpenProcess(PROCESS_QUERY_INFORMATION or PROCESS_VM_READ, False, PrIDS[i]); if (ProzessHandle <> 0) then begin EnumProcessModules(ProzessHandle, @ModulHandle, SizeOf(modulhandle), Bia); GetModuleFilenameEx(Prozesshandle, ModulHandle, PrName, SizeOf(PrName)); result.Add(ExtractFileName(PrName)+ ' --> '+ ExtractFilePath(PrName)); //result.Add(PrName); //result.Add(ExtractFileName(PrName)); CloseHandle(ProzessHandle); end; end; {for i} end else begin MessageDlg('PrID-Array zu klein', mtError, [mbOk], 0)//if bia < sizeof... end; end else begin RaiseLastOSError(); //if enumprocesses... end; {-} end; begin tmpList:=ProcessList; try LBProcessList.items.assign(tmpList); finally tmpList.Free; end; {finally} Caption:=prvCaption+_retTaskRunning(LBProcessList.Count); end;
Delphi-Quellcode:
@Delphi-Laie
....
{-} LBProcessList.Clear; LBProcessList.MultiSelect:=True; bevProcessList.SetBounds(8,8,4*bDX-4,bTop-bDY-16); LBProcessList.SetBounds(8+2,8+2,4*bDX-8,bTop-bDY-20); LBProcessList.ScrollWidth:=AWidth; LBProcessList.Sorted:=True; LBProcessList.ShowHint:=AisAllowHints; LBProcessList.Hint:=_retHint(062); {-062: Running Tasks Under Your Login-} {-} _updateProcess; {-} .... Zitat:
Vielen Dank für die prompte Hilfe. Mit freundlichen Grüßen Manfred Zenns |
Re: Alle Rechner-Prozesse Anzeigen Lassen
|
Re: Alle Rechner-Prozesse Anzeigen Lassen
Und welche Prozesse fehlen da jetzt angeblich?
|
Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
lg. Astat |
Re: Alle Rechner-Prozesse Anzeigen Lassen
Kannst du mal welche benennen? Welche Prozesse laufen denn in Ring0?
|
Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
|
Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
|
Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
etwas zu finden. |
Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
|
Re: Alle Rechner-Prozesse Anzeigen Lassen
Schönen Guten Morgen,
danke für das zahlreiche Echo auf meine Anfrage. Um welche Prozesse geht es mir eigentlich? Wenn es eine Möglichkeit gibt, Prozesse vor dem standardmäßig im Betriebssystem mitgeliefertem TaskManager zu verstecken, dann muß es doch auch eine Möglichkeit geben, mit Routinen des Betriebssystemes diese zu finden. Klar, daß es keine 100%ig Lösung geben kann, weil hier zwei Gruppen von Leuten gegeneinander antreten. Und klar ist auch, daß eine riesige Interessengemeinschaft, ich nenne die mal AntiVir-Software-Hersteller bestrebt sind, ihre herausgefundenen Erkenntnisse für sich zu behalten, um Ihre Jobs zu sichern. Auf der einen Seite sind es aber doch gerade Leute mit Ihrem Wissen über die Betriebssysteme, die solche Sachen schreiben können. Weil es eben Software ist, kann man alles damit machen - und daß Shareware-Software auch Hintertürchen verwenden wird, um irgendwelchen Prozesse auf dem eigenen PC laufen zu lassen, möchte ich hier nicht bewerten. Zu Astat, ja Du (Sie) hast es auf den Punkt gebracht, was ich meinte mit "allen" Prozessen. @ Astat #9 Zitat:
im Hintergrund, wenn es Möglichkeiten gibt, alles aufzudecken oder mitzuloggen, was der eigene PC so treibt, während man in Ruhe und ahnungslos seine Arbeit damit erledigt. Mit freundlichen Grüßen Manfred Zenns |
AW: Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
an dich Kaki, aber für ein großes DANKE ist es nie zu spät. Werde mich durch deine Seiten mal durchschmökern. Vielen vielen Dank und bis Demnächst. MfG Manfred Zenns |
AW: Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
![]() detector for hidden processes. It has several listing methods to detect processes, making use of native apis and kernel mode drivers (The screenshot details complete available options). The article shows how the author of Process Hunter, Ms-Rem, created the application, describing the concepts used in detail alongside code executing those concepts. Full source code of Process Hunter is attached at the bottom of the page. |
AW: Re: Alle Rechner-Prozesse Anzeigen Lassen
Zitat:
Und mal mit dem Debugger anschauen, was die Win32-Funktionen zum Auflisten von Prozessen an unterliegenden NT-Funktionen aufrufen und es mit jenen direkt probieren - gibt es Differenzen? Billige Rootkits verstecken sich ggfls. nur auf Win32-Ebene. Signaturbasierte Suchen können zudem etwa nachschauen, ob Mutexe/Semaphore mit fixem Namen existieren - bringt aber nur gegen jeweils konkrete Rootkits etwas. Der Punkt, warum sich zu sowas kaum Code findet, dürfte sein, dass der Zeitaufwand hier einfach sehr hoch ist - viele Betriebssystemfunktionen sind offiziell far nicht und inoffiziell nur teilweise dokumentiert - und daher eben hauptsäclich für berufliche Anwender "interessant", die schon aus arbeitsvertraglicher Sicht nicht einfach Code zur Verfügung stellen können. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:32 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz