Hi,
Ich hoffe ihr könnt mir helfen. Ich habe mir eine
DLL geschrieben, die in eine
WinApi Funktion injected werden soll. Dazu verwende ich madCodeHook. Soweit so gut.
Jetzt möchte ich der
DLL eine Callback Funktion übergeben, die ausgeführt wird wenn die
WinApi Funktion aufgerufen wird. Leider passier aber absolut gar nichts. Gehen eigene Callback Funtionen nicht in einer
DLL, die injected wird?
Hier der Code:
DLL:
Delphi-Quellcode:
library TestLIB;
uses
Windows, SysUtils, WinSock, madCodeHook;
type
THKLibOnPermission = procedure();
PHKLibOnPermission = ^THKLibOnPermission;
{$R *.res}
var
{ Externe Funktionen }
OnPermission: THKLibOnPermission;
{ Hooks }
AcceptNext: function(S: TSocket; Addr: PSockAddr; AddrLen: PInteger): TSocket; stdcall;
{ Legt die Funktion die ausgeführt werden soll fest }
procedure Init(_OnPermission: Pointer);
var pp: PHKLibOnPermission;
begin
pp := _OnPermission;
OnPermission := pp^;
end;
function AcceptProc(S: TSocket; Addr: PSockAddr; AddrLen: PInteger): TSocket; stdcall;
begin
if Assigned(OnPermission) then
OnPermission();
end;
exports
Init;
begin
{ CollectHooks ausführen um Hooks zu beschleunigen }
CollectHooks();
{ WSOCK32.DLL hooken }
HookAPI('WSOCK32.DLL', 'accept', @AcceptProc, @AcceptNext);
FlushHooks();
end.
Und jetzt der Code meiner Anwendung:
Delphi-Quellcode:
program Test;
{$APPTYPE CONSOLE}
uses
Windows, SysUtils, madCodeHook, WinSock;
type
THKLibOnPermission = procedure();
procedure Init(_OnPermission: Pointer); register; external 'TestLIB.dll';
procedure sPermission();
begin
{ Um anzuzeigen das die Prozedur ausgeführt wurde }
FileClose(FileCreate('C:\test.txt'));
end;
begin
readln;
Init(@sPermission);
InjectLibrary(ALL_SESSIONS or SYSTEM_PROCESSES, 'TestLIB.dll');
Sleep(20000);
UnInjectLibrary(ALL_SESSIONS or SYSTEM_PROCESSES, 'TestLIB.dll');
end.