![]() |
Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse fal
Hallo,
Ich will eine Funktion aus einer DLL abändern bzw. umleiten auf meine eigene. Wenn also die Funktion X aus der DLL aufgerufen wird soll die Funktion Y aus meinem Programm ausgeführt werden. Zur zeit bin ich soweit, dass ich an die Stelle im DLL-Speicher wo die eigentliche Funktion steht einen Sprung zu meiner Funktion aus der Exe schreibe. Allerdings ist die Adresse wohl falsch (verständlich da die DLL eine andere Basisadresse hat). Zur Zeit mache ich das Sinngemäß so: AdresseMeineFunktion := @MeineFunktion; dann füge ich in den DLL-Speicher folgendes ein (natürlich als asm-Code): jmp dword ptr [AdresseMeineFunktion] Aber wie gesagt stimmt die Adresse innerhalb der DLL nicht. Wie kann ich die Adresse umrechnen so das die DLL dann wirklich auf den Speicher der Exe zeigt wo die DLL liegt. Gegeben ist: Adresse der Exe-Funktion HINSTANCE der EXE HINSTANCE der DLL Adresse der DLL-Funktion |
Re: Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse
Hi,
du musst die Addresse erst ausrechnen AdrVonDeinerFunktion - AddresseAnDerDuSchreibst - 5. Also bei dir: Integer(@MeineFunktion) - Integer(@FunktionX) - 5 |
Re: Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse
wie kommst du auf "5"? wofür steht die zahl?
|
Re: Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse
Fuer die 5 byte die der Jmp + Adresse benoetigt. (E9AAAAAAAA : E9(Jump) + 4 byte Addresse)
|
Re: Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse
es ging doch ohne rumrechnen. mein fehler lag in der asm-anweisung.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:09 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