Показать сообщение отдельно
Старый 18.12.2009, 00:35   #36
Admin!
 
Аватар для xkor
 
Регистрация: 04.08.2007
Сообщений: 2,360
Сказал Спасибо: 113
Имеет 1,566 спасибок в 651 сообщенях
xkor на пути к лучшему
По умолчанию

Fertis, ок, вот так хукаю функцию UNetworkHandler::AddNetworkQueue
delphi Код:
HookProc('engine.dll','?AddNetworkQueue@UNetworkHandler@@UAEHPAUNetworkPacket@@@Z',            @UNetworkHandler_AddNetworkQueue_Hook,@UNetworkHandler_AddNetworkQueue_Original);
в результате при вызове клиентом AddNetworkQueue сначала вызывается моя UNetworkHandler_AddNetworkQueue_Hook:
delphi Код:
procedure UNetworkHandler_AddNetworkQueue_Hook(NetworkPacket: Pointer); stdcall; asm   push    ecx   push    [ebp+8]   push    ecx   call    UNetworkHandler_AddNetworkQueue_New   pop     ecx end;
которая собсно всего лишь прослойка к полноценной функции UNetworkHandler_AddNetworkQueue_New:
delphi Код:
procedure UNetworkHandler_AddNetworkQueue_New(unh: Integer; np: PNetworkPacket); stdcall; begin   // тут код для логирования того что пришло в функцию   // сохраняем указатель на объект UNetworkHandler   nh:=Pointer(unh);   // Вызываем клиентскую UNetworkHandler::AddNetworkQueue   UNetworkHandler_AddNetworkQueue_Call(np); end;
ну просто для импорта достаточно засунуть в UNetworkHandler_AddNetworkQueue_Original указатель на UNetworkHandler::AddNetworkQueue и вызвать UNetworkHandler_AddNetworkQueue_Call, короче примерно так:
delphi Код:
var   nh: Pointer; // <-- в эту переменную надо засунуть указатель на объект UNetworkHandler   UNetworkHandler_AddNetworkQueue_Original: procedure(NetworkPacket: Pointer); stdcall; procedure UNetworkHandler_AddNetworkQueue_Call(NetworkPacket: Pointer); stdcall; asm     mov     ecx, nh     mov     esp, ebp     pop     ebp     jmp     [UNetworkHandler_AddNetworkQueue_Original] end; begin   UNetworkHandler_AddNetworkQueue_Original:=GetProcAddress('engine.dll','?AddNetworkQueue@UNetworkHandler@@UAEHPAUNetworkPacket@@@Z');     // вызываем импортированную функцию   UNetworkHandler_AddNetworkQueue_Call(параметр); end.

Добавлено через 4 минуты
UNetworkHandler_AddNetworkQueue_Hook и UNetworkHandler_AddNetworkQueue_Call прослойки нужные для того чтоб перейти от thiscall к stdcall соглашению
__________________
Я здесь практически не появляюсь!, Skype - ikskor

Последний раз редактировалось xkor, 18.12.2009 в 00:35. Причина: Добавлено сообщение
xkor вне форума   Ответить с цитированием
За это сообщение xkor нажился 12 спасибками от: