Извините, ничего не найдено.

Не расстраивайся! Лучше выпей чайку!
Регистрация
Справка
Календарь

Вернуться   forum.boolean.name > Программирование игр для компьютеров > C++

Ответ
 
Опции темы
Старый 05.04.2012, 01:33   #1
Mick
AnyKey`щик
 
Регистрация: 22.07.2011
Сообщений: 6
Написано одно полезное сообщение
DETOURS, Перехват API средствами Detours

Пытаюсь разобраться в библиотеке Detours. Столкнулся с проблемой - мой перехват не работает.
Делаю так:
создал программку, использующую MessageBoxA().
создал DLL для подключения к этому приложению.
создал программку, внедряющую эту DLL.
В результате на выходе - ничего.
Ниже привожу листинги.
Помогите, пожалуйста, разобраться, где, кроме ДНК ошибка.
DLL:
...
static int (WINAPI *Original_MessageBox)(HWND hWnd,LPCSTR lpText,LPCSTR lpCaption, UINT uType)=MessageBoxA;
...
BOOL APIENTRY DllMain( HMODULE hModule,
                       DWORD  ul_reason_for_call,
                       LPVOID lpReserved
                     )
{                
    switch (ul_reason_for_call)
    {
    case DLL_PROCESS_ATTACH:
        
        DetourRestoreAfterWith();
        
        
        DetourTransactionBegin();
        DetourUpdateThread(GetCurrentThread());
        DetourAttach(&(PVOID&)Original_MessageBox, My_MessageBox);
        
        if(DetourTransactionCommit() == NO_ERROR) Original_MessageBox(0,"attach ok "," ", MB_OK);
        else Original_MessageBox(0,"attach failed "," ", MB_OK);
    case DLL_THREAD_ATTACH:break;
    case DLL_THREAD_DETACH:break;
        
        
        
    case DLL_PROCESS_DETACH:
        DetourTransactionBegin();
                DetourUpdateThread(GetCurrentThread());
                DetourDetach(&(PVOID&)Original_MessageBox, My_MessageBox);
        DetourTransactionCommit();
        break;
    }
    return TRUE;
}
...
Установщик хука:
...
STARTUPINFO si;
PROCESS_INFORMATION pi;
...
ZeroMemory(&si, sizeof(STARTUPINFO));
            ZeroMemory(&pi, sizeof(PROCESS_INFORMATION));
            si.cb = sizeof(STARTUPINFO);
           
            DetourCreateProcessWithDll("", 
        "c:\\TEMP\\11\\gertva.exe",
        NULL,
        NULL, 
        FALSE, 
        CREATE_DEFAULT_ERROR_MODE ,//| CREATE_SUSPENDED,
        NULL, 
        "c:\\TEMP\\11\\",
        &si, &pi, 
        "c:\\TEMP\\11\\dll.dll",//DetourPath
        NULL); 
...
Процесс не создается почему-то(((
(Offline)
 
Ответить с цитированием
Старый 05.04.2012, 10:57   #2
h1dd3n
Бывалый
 
Аватар для h1dd3n
 
Регистрация: 19.06.2008
Сообщений: 679
Написано 264 полезных сообщений
(для 450 пользователей)
Ответ: DETOURS, Перехват API средствами Detours

Не знаю что значит "DetourCreateProcessWithDll"...
Тебе просто нужно заинжектить длл в нужную программу, сделать это можно буквально за 10 минут. Суть (там c#, но код очень простой): http://www.mpgh.net/forum/250-c-prog...-c-source.html
С майкрософтовскими детоурсами у меня и самого не заладилось, советую взять что-нибудь наподобие http://www.gamedeception.net/threads/21803-DetourXS-v2 - намного проще использовать + есть примеры и т.д.
__________________
(Offline)
 
Ответить с цитированием
Ответ


Опции темы

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


Часовой пояс GMT +4, время: 12:17.


vBulletin® Version 3.6.5.
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Перевод: zCarot
Style crйe par Allan - vBulletin-Ressources.com