AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Prozess aneignen

Ein Thema von Neutral General · begonnen am 28. Feb 2008 · letzter Beitrag vom 29. Feb 2008
 
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#9

Re: Prozess aneignen

  Alt 29. Feb 2008, 10:20
Hi,

Also ich habe es jetzt mit der DLL-Injektion versucht. Das funktioniert auch sogar schon - manchmal.
Bzw. nicht bei allen Programmen...

Injection-Programm:
Delphi-Quellcode:
const
  WM_GETMODULE = WM_USER + 1;

type
  
type
  TWMGetModule = packed record
    Msg: Cardinal;
    Handle: hModule;
    Unused1: Longint;
    Unused2: Longint;
  end;

  Taber = class(TForm)
    Button1: TButton;
    procedure FormCreate(Sender: TObject);
    procedure FormDestroy(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    hExplore: THandle;
    procedure OnModule(var Msg: TWMGetModule); message WM_GETMODULE;
  end;

const
  DLLName = 'dll.dll';

implementation

procedure Taber.FormCreate(Sender: TObject);
var id: Cardinal;
begin
  // z.B. (klappt mit IrfanView nicht, Klassenname stimmt (Mit Winspy überprüft), Handle etc auch alles in Ordnung.)
  GetWindowThreadProcessId(FindWindow('IrfanView',nil),id);
  hExplore := OpenProcess(PROCESS_ALL_ACCESS,true,id);
end;

procedure Taber.Button1Click(Sender: TObject);
var Params: Pointer;
    LoadLibAddr: Pointer;
    bw,tid: Cardinal;
begin
  Params := VirtualAllocEx(hExplore,nil,Length(DLLName),MEM_COMMIT,PAGE_READWRITE);
  WriteProcessMemory(hExplore,Params,@DLLName[1],Length(DLLName),bw);

  LoadLibAddr := GetProcAddress(GetModuleHandle('kernel32.dll'),'LoadLibraryA');

  CreateRemoteThread(hExplore,nil,0,LoadLibAddr,Params,0,tid);
end;

procedure Taber.OnModule(var Msg: TWMGetModule);
begin
  ShowMessage(IntToStr(Msg.Handle));
end;
DLL:
Delphi-Quellcode:
library DLL;

uses
  Windows, Messages, Dialogs;

{$R *.res}

var wnd: hwnd;
begin
  ShowMessage('DLL geladen!'); // Fast alles auschließlich zum testen.
  wnd := FindWindow('Taber',nil);
  SendMessage(wnd,WM_USER+1,hInstance,0);
end.
Erklärung:
Also das ganze funktioniert weitgehend. Aber nur bei einigen Programmen. Bei selbst erstellten Anendungen (mit Delphi) geht es und auch bei der Delphi-IDE. Bei den Programmen bei denen ich es sonst versucht habe (u.a. WinRAR, Irfan-View) funktionierte es nicht, das heißt ich bekam die Message "Dll geladen!" nicht. CreateRemoteThread liefert mir aber IMMER ein gültiges hThread-Handle und die Ziel-Andwendung stürzt nicht ab (Bei falschen Parametern passiert das bei mir immer^^).

Das einzige was noch nicht so ganz funktioniert, auch nicht bei den Programmen wo es funktioniert ( ) ist das senden des Modul-Handles, um die DLL in der Fremden Anwendung wieder freigeben zu lassen. Schreibe ich in die OnModule-Methode

FreeLibrary(Msg.Handle); dann stürzt MEIN Programm ab.

Gruß
Neutral General
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
 


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 10:04 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