![]() |
Subclassing einer fremden Application, warum funzt das net ?
Hallo !
Ich wollte die WndProc einer fremden Application subclassen, aber irgendwie funzt das net. Also die neu definierte NewWinProc wird niemals aufgerufen. Es passiert einfach gar nix ..! Wo liegt der Fehler ? Danke !
Delphi-Quellcode:
var OldWinProc: Integer; //////////////////////////////////////////////////////////////////////////////// function NewWinProc(hWnd: HWND; Msg: WORD; wParam: WORD; lParam: LONGINT): LONGINT; var MessageProcessed: Boolean; begin MessageProcessed := False; // case Msg of // end; {end of case Msg } if not MessageProcessed then Result := CallWindowProc(@OldWinProc,hWnd,Msg,wParam,lParam) else Result := 0; end; ///////////////////////////////////////////////////////////////////////////////// procedure SubClassWin(hWnd: HWND); begin OldWinProc := SetWindowLong(hWnd,GWL_WNDPROC,integer(@NewWinProc)); end; ///////////////////////////////////////////////////////////////////////////////// procedure UnSubClassWin(hWnd: HWND); begin SetWindowLong(hWnd,GWL_WNDPROC,OldWinProc); end; ///////////////////////////////////////////////////////////////////////////////// procedure TForm1.Button1Click(Sender: TObject); var h : hwnd; begin h := findwindow('notepad', nil); if h > 0 then subclasswin(h); end; |
Re: Subclassing einer fremden Application, warum funzt das n
Der Fehler liegt darin, dass das nicht geht. Zu mindest wohl nicht so einfach. Warum es nicht geht und wie man es amcht, kann ich dir leider auch nicht sagen.
|
Re: Subclassing einer fremden Application, warum funzt das n
IM PSDK klingt es so, als würde es unter Win9x gehen:
Zitat:
Bei NTff müsste es eigentlich irgendwie über VirtualAllocateEc und Read/WriteProcessMemoyr gehen. Man müsste den Aufruf von SetWindowLong irgendwie in den fremden Prozess kriegen und die eigene WindowProc ebenfalls (natürlich auch die Wiederherstellung der Original-Fenterprozedur). Dann müsste es eigentlich funktionieren, denn es würde die Bedingung "belongs to the same process as the calling thread" gelten. So, wie du jetzt Code in einen fremden Prozess kopierst, kann dir (hoffentlich) Luckie sagen (oder er kann mir erklären, wieso das, was ich geschrieben hab, nicht funktioniert :wink: ). Oder schau dir mal LuckieDips (auf ![]() |
Re: Subclassing einer fremden Application, warum funzt das n
Die Dips haben nichts mit Subclassing am Hut und mit Read- / WriteProcessMemory liest man nur Speicher aus und damit dürfte man auf dem falschen Weg sein.
|
Re: Subclassing einer fremden Application, warum funzt das n
Aber soweit ich das kopiert hab, kopiert man doch irgendwie ausführbaren Code in einen fremden Prozess, oder?
|
Re: Subclassing einer fremden Application, warum funzt das n
Nein Speicher.
|
Re: Subclassing einer fremden Application, warum funzt das n
Liegt der Code nicht auch im Speicher? Ich meinte, sollte es nicht möglich sein, den Speicher, in dem sich der Code befindet, in den fremden Prozess zu kopieren?
|
Re: Subclassing einer fremden Application, warum funzt das n
Klar tut er das. Nur ist es ein Unterschied, ob es Programmcode ist oder ob es Daten (Variablen) sind.
|
Re: Subclassing einer fremden Application, warum funzt das n
deine alte poc musst du als pointer in den var parameter aufnehmen . in der initialization musst du deiner alten proc nil zuweisen und deine neue procedure musst mit stdcall aufgerufen werden.
so zumindest schreibt es kosch in seinem buch raik |
Re: Subclassing einer fremden Application, warum funzt das n
Hi,
Zitat:
Einfachste Möglichkeit: - DLL mit Hook um in den anderen Adressraum zu gelangen - SetWindowLong()/SetClassLong() um WndProc umzubiegen (siehe oben) - MMF zur "Interprocess Communication" Gruß, Markus |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:53 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 by Thomas Breitkreuz