AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Prozesse Beenden (wenn man nur Prozessnamen hat)
Thema durchsuchen
Ansicht
Themen-Optionen

Prozesse Beenden (wenn man nur Prozessnamen hat)

Ein Thema von Headshot037 · begonnen am 31. Jan 2009 · letzter Beitrag vom 1. Feb 2009
Antwort Antwort
Headshot037

Registriert seit: 31. Jan 2009
Ort: Thüringen
6 Beiträge
 
#1

Prozesse Beenden (wenn man nur Prozessnamen hat)

  Alt 31. Jan 2009, 23:49
Hallo Leute..
Als erstes möchte ich euch bitten, mich nich zu hart zu behandeln, bin noch neu hier ^^
Ich programmiere mit Delphi seit... 2 Wochen vielleicht =D Ich habe nach ner Lösung schon das halbe Forum durchkramt, stundenlang gelesen und ich bekomms immernoch nicht hin.
Ich möchte ein Programm schreiben, das einen Bot auf einem Rootserver startet und kontrolliert. Ich bin schon soweit, dass für den bot übergebene Parameter (per PHP) richtig übernommen und eingesetzt werden und der Bot richtig gestartet wird. *stolz bin*
Der BOt soll aber von mehreren Tausend Benutzern gestartet werden können. Daher dachte ich mir, muss ich jedem Bot ne Nummer zuweisen. Das funktioniert auch. Jeder Benutzer bekommt bei dem Registrieren auf der Webseite eine Nummer zugewiesen, die auch ordnungsgemäß übergeben wird. Die Datei, die also ausgeführt wird, heißt also nun bot[nutzer-id].exe also z.b. bot313373.exe ^^

Für Nutzer, die nichts an mich bezahlen (Free-User), wäre das aber vorteilhaft, denn sie besuchen einmal meine Seite und der Bot läuft durchgängig... daher will ich eine 6-std-Sperre einbauen, die den Bot nach 6 Std beendet. Das mit der 6-Std-Wartezeit hab ich auch raus (hab mir von irgendwem ausm Forum, NegaH oder so, den Code geklaut ^^ thx ^^).
Jetzt suche ich schon seit Stunden nach ner möglichkeit, den jeweiligen Bot zu beenden. Im Task-Manager sind die Bots ja jeweils nummeriert, nur leider weiß ich nicht, wie ich die Prozess-Handles (heißen die so?) rausbekommen kann.
Das Projekt ist für mich enorm wichtig, und es scheitert mal wieder nicht an der Webseite oder deren datenbank, sondern an der Umsetzung in Delphi =,(

Ich hoffe, ihr könnt mir helfen. (Natürlich könnt ihr das, nur WERDET ihr es?^^)
Danke im Voraus.

Headshot037
Delphi is geil ^^ Wenn mans kann =,(
  Mit Zitat antworten Zitat
Benutzerbild von stoxx
stoxx

Registriert seit: 13. Aug 2003
1.111 Beiträge
 
#2

Re: Prozesse Beenden (wenn man nur Prozessnamen hat)

  Alt 1. Feb 2009, 00:01
Zitat:
Ich hoffe, ihr könnt mir helfen. (Natürlich könnt ihr das, nur WERDET ihr es?^^
ganz schön anmaßend für den allerersten Post in einer Community.
Phantasie ist etwas, was sich manche Leute gar nicht vorstellen können.
  Mit Zitat antworten Zitat
Benutzerbild von stoxx
stoxx

Registriert seit: 13. Aug 2003
1.111 Beiträge
 
#3

Re: Prozesse Beenden (wenn man nur Prozessnamen hat)

  Alt 1. Feb 2009, 00:13
aber bitteschön, Nico war mal so freundlich, man hofft ja, dass es ihm gut geht



Aufruf mit:

KillProcess(FindWindowByFilename('notepad.exe', False));

Delphi-Quellcode:
unit xAPIUtils;

interface
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs;

  function FindWindowByFilename(const Filename: string; Path: Boolean): HWND;
  procedure KillProcess(hWindowHandle: HWND);

implementation
uses TlHelp32, PSApi;

//==============================================================================
function FindWindowByProcessId(ProcessId: DWORD): HWND;
  type
    PParam = ^TParam;
    TParam = record
      ProcessId: DWORD;
      WndHandle: HWND;
    end;
  // Callback function
  function EnumWindowsProc(Wnd: HWND; var Param: TParam): BOOL; stdcall;
  var
    ProcessId: DWORD;
    begin Result := True;
    // visible only
    if IsWindowVisible(Wnd) then
    begin
      ProcessId := 0;
      GetWindowThreadProcessId(Wnd, @ProcessId);
      if (ProcessId = Param.ProcessId) then
      begin
        Param.WndHandle := Wnd;
        Result := False;
      end;
    end;
  end;
 var
   Param: TParam;
 begin
   Param.ProcessId := ProcessId;
   Param.WndHandle := 0;
   EnumWindows(@EnumWindowsProc, LPARAM(@Param));
   Result := Param.WndHandle;
 end;

//==============================================================================
function FindWindowByImage9x(const Filename: string; Path: Boolean): HWND;
var
  ProcSnap: THandle;
  ProcEntry: TProcessEntry32;
  ModSnap: THandle; ModEntry:
  TModuleEntry32;
begin
  Result := 0;
  // Get list of processes (IDs)
  ProcSnap := CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
  if (ProcSnap <> INVALID_HANDLE_VALUE) and (ProcSnap <> 0) then
  try
    // Loop through process list
    ZeroMemory(@ProcEntry, SizeOf(TProcessEntry32));
    ProcEntry.dwSize := SizeOf(TProcessEntry32);
    if Process32First(ProcSnap, ProcEntry) then
      repeat
        // Get list of modules
        ModSnap := CreateToolhelp32Snapshot(TH32CS_SNAPMODULE, ProcEntry.th32ProcessID);
        if (ModSnap <> INVALID_HANDLE_VALUE) and (ModSnap <> 0) then
        try
           // get the first module only
           // ( let's call it image-used-to-create-the-process )
           ZeroMemory(@ModEntry, SizeOf(TModuleEntry32));
           ModEntry.dwSize := SizeOf(TModuleEntry32);
           if Module32First(ModSnap, ModEntry) then
           begin
             // Compare _case_insensitive_
             if Path and (StrIComp(ModEntry.szExePath, PChar(Filename)) = 0) then
               // with path
               Result := FindWindowByProcessId(ProcEntry.th32ProcessID);
             if (not Path) and (StrIComp(ModEntry.szModule, PChar(Filename)) = 0) then
               // without path
               Result := FindWindowByProcessId(ProcEntry.th32ProcessID);
           end;
         finally
           CloseHandle(ModSnap);
         end;
       until (Result <> 0) or not Process32Next(ProcSnap, ProcEntry);
   finally
     CloseHandle(ProcSnap);
   end;
end;


//==============================================================================
function FindWindowByImageNt(const Filename: string; Path: Boolean): HWND;
type
  PProcList = ^TProcList;
  TProcList = array [Word] of DWORD;
var
  ListSize: DWORD;
  ListNeed: DWORD;
  ProcList: PProcList;
  Loop: Word;
  Process: THandle;
  Module: HMODULE;
  ModName: array [0..MAX_PATH] of Char;
begin
  Result := 0;
  ListSize := 1024 * SizeOf(DWORD);
  ProcList := GetMemory(ListSize);
  try
    // Get list of processes (IDs)
    ListNeed := 0;
    while EnumProcesses(@ProcList[0], ListSize, ListNeed) and (ListNeed >= ListSize) do
    begin
      Inc(ListSize, 1024 * SizeOf(DWORD));
      FreeMemory(ProcList);
      ProcList := GetMemory(ListSize);
      if not Assigned(ProcList) then
        Exit;
    end;
    // Loop through process list
    for Loop := 0 to ListNeed div SizeOf(DWORD) - 1 do
    begin
      // Open the process (to read module)
      Process := OpenProcess(PROCESS_QUERY_INFORMATION or PROCESS_VM_READ,
        False, ProcList[Loop]);
      if (Process <> 0) then
      try
        // get the first module only
        // ( let's call it image-used-to-create-the-process )
        ListSize := SizeOf(DWORD);
        ListNeed := 0;
        if EnumProcessModules(Process, PDWord(@Module), ListSize, ListNeed) and
           (ListNeed >= ListSize) then
        begin
          ModName[0] := #0;
          // Get the filename with/without path
          if Path then
            GetModuleFileNameEx(Process, Module, ModName, SizeOf(ModName))
          else
            GetModuleBaseName(Process, Module, ModName, SizeOf(ModName));
          // Compare _case_insensitive_
          if (StrIComp(ModName, PChar(Filename)) = 0) then
          begin
            // Find first window by process id
            Result := FindWindowByProcessId(ProcList[Loop]);
            if (Result <> 0) then
              Break;
          end;
        end;
      finally
        CloseHandle(Process);
      end;
    end;
  finally
    if Assigned(ProcList) then
      FreeMemory(ProcList);
  end;
end;


//==============================================================================

function FindWindowByFilename(const Filename: string; Path: Boolean): HWND;
begin
  if (Win32Platform = VER_PLATFORM_WIN32_NT) and (Win32MajorVersion <= 4) then
    // Windows NT 4.0 or earlier (using PSApi)
    Result := FindWindowByImageNt(Filename, Path)
  else
    // else (using TlHelp32)
    Result := FindWindowByImage9x(Filename, Path);
end;



//==============================================================================


procedure KillProcess(hWindowHandle: HWND);
var
  hprocessID: INTEGER;
  processHandle: THandle;
  DWResult: DWORD;
begin
 // SendMessageTimeout(hWindowHandle, WM_CLOSE, 0, 0,
 // SMTO_ABORTIFHUNG or SMTO_NORMAL, 5000, DWResult);

  if true or isWindow(hWindowHandle) then
  begin
    // PostMessage(hWindowHandle, WM_QUIT, 0, 0);

    { Get the process identifier for the window}
    GetWindowThreadProcessID(hWindowHandle, @hprocessID);
    if hprocessID <> 0 then
    begin
      { Get the process handle }
      processHandle := OpenProcess(PROCESS_TERMINATE or PROCESS_QUERY_INFORMATION,
        False, hprocessID);
      if processHandle <> 0 then
      begin
        { Terminate the process }
        TerminateProcess(processHandle, 0);
        CloseHandle(ProcessHandle);
      end;
    end;
  end;
end;



end.
Phantasie ist etwas, was sich manche Leute gar nicht vorstellen können.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 01: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