Einzelnen Beitrag anzeigen

Astat

Registriert seit: 2. Dez 2009
Ort: München
320 Beiträge
 
Lazarus
 
#10

Re: Alle Prozesse bis auf einen einfrieren

  Alt 8. Dez 2009, 00:14
Hallo Delphi-Narr, da ich in meinem Bekanntenkreis immer wieder mit hartnäckigen
Schädlingen konfrontiert bin, habe ich mir mal ein eigenes Kill util geschrieben.
Da verwende ich die Technik, bei allen nicht zum System gehörenden Prozessen, deren Threads
zu suspendieren. Geht auch bei den meisten Systemprozessen. Wenn dann alles konserviert ist,
beginnt die Ausmisterei.

Also interessieren dürfte dich die Funktion:

Delphi-Quellcode:
function TProcList.SecureKill: boolean;

...

          //-- Bei Winlogon.exe threads suspendieren
          if (filename = 'winlogon.exe') then begin
            dwArray := GetThreadID(filename);
            for x := 0 to Length(dwArray) - 1 do begin
              hThread := OpenThread(
                THREAD_GET_CONTEXT or THREAD_SET_CONTEXT or THREAD_SUSPEND_RESUME, false,
                  dwArray[x]
                  );
              if hThread <> 0 then SuspendThread(hThread);
            end;
          end;
Source der Classe ist beigefügt.

lg. Astat
Angehängte Dateien
Dateityp: pas process_180.pas (19,8 KB, 10x aufgerufen)
Lanthan Astat
06810110811210410503210511511603209711003210010110 9032084097103
03211611111604403209711003210010110903210010510103 2108101116122
11610103209010110510810103206711110010103210511003 2068101108112
10410503210310111509910411410510109810111003211910 5114100046
  Mit Zitat antworten Zitat