Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse falsch (https://www.delphipraxis.net/72628-aus-dll-funktion-aus-exe-aufrufen-procedureadresse-falsch.html)

SirThornberry 4. Jul 2006 10:11


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

_rEdoX 4. Jul 2006 10:25

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

SirThornberry 4. Jul 2006 10:44

Re: Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse
 
wie kommst du auf "5"? wofür steht die zahl?

_rEdoX 4. Jul 2006 11:31

Re: Aus DLL Funktion aus Exe aufrufen -> ProcedureAdresse
 
Fuer die 5 byte die der Jmp + Adresse benoetigt. (E9AAAAAAAA : E9(Jump) + 4 byte Addresse)

SirThornberry 4. Jul 2006 11:53

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