Модераторы: feodorv, GremlinProg, xvr, Fixin
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Не отрабатывает хук, на этапе интеграции DLL 
:(
    Опции темы
epsilon
Дата 13.2.2007, 11:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 16.10.2006

Репутация: нет
Всего: нет



В общем задача такая: поставить локальный  хук на оконные сообщения в чужом процессе при помощи нитеграции DLL, в которой и будет обработчик.
Проблема такая: хук ставится, но не отрабатывает
Интеграция DLL через CreateRemoteThread по Рихтеру.

Код

...
static HMODULE ModuleFromAddress(PVOID pv)
{
 MEMORY_BASIC_INFORMATION mbi;
 return ((VirtualQuery(pv,&mbi,sizeof(mbi))!=0) ? (HMODULE)mbi.AllocationBase : NULL);
}
...
 //это в секции DLL_PROCESS_ATTACH
  HMODULE hMod = ModuleFromAddress((HOOKPROC)CallWndRetProc);// GetModuleHandle(NULL);
     HOOKPROC pProcAddr = GetProcAddress(hinst,"CallWndRetProc");

     HANDLE shot = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD,0);
     THREADENTRY32 sThreadEntry;
     sThreadEntry.dwSize = sizeof(sThreadEntry);


     int i=0;
     for(BOOL fOK = Thread32First(shot,&sThreadEntry);fOK;fOK = Thread32Next(shot,&sThreadEntry))
     {
      if ((sThreadEntry.th32OwnerProcessID==pid)&&(sThreadEntry.th32ThreadID!=thid))
      {
       hhkWndMess[i++]  = SetWindowsHookEx(WH_CALLWNDPROCRET,pProcAddr,hMod,sThreadEntry.th32ThreadID);

      }
     }
...

PM MAIL   Вверх
dumb
Дата 15.2.2007, 04:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


sceloglauxalbifacies
****


Профиль
Группа: Экс. модератор
Сообщений: 2929
Регистрация: 16.6.2006

Репутация: 27
Всего: 158



Цитата(epsilon @  13.2.2007,  11:42 Найти цитируемый пост)
Интеграция DLL через CreateRemoteThread по Рихтеру.

масло масляное. SetWindowsHookEx сама подгружает твою dll в нужный(или во все) процесс.

перечислять потоки и расставлять на них хуки нужно в хост-приложении.

как вариант - в хосте создать mmf с массивом pid'ов, а в DLL_PROCESS_ATTACH открывать его, сравнивать с текущим pid(GetCurrentProcessId) и если свой pid не найден, вываливаться с 0. или, что менее требовательно к ресурсам, выставить флаг для функции-обработчика хука, в зависимости от которого либо производить обработку, либо просто return CallNextHookEx.
PM MAIL   Вверх
epsilon
Дата 16.2.2007, 09:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 16.10.2006

Репутация: нет
Всего: нет



это уже от отчаяния
Код

 hhkWndMess[i++]  = SetWindowsHookEx(WH_CALLWNDPROCRET,pProcAddr,hMod,sThreadEntry.th32ThreadID);

 пробовал так
Код

 hhkWndMess[i++]  = SetWindowsHookEx(WH_CALLWNDPROCRET,pProcAddr,NULL,sThreadEntry.th32ThreadID);

и так 
Код

 hhkWndMess[i++]  = SetWindowsHookEx(WH_CALLWNDPROCRET,pProcAddr,(HINSTANCE)0x400000,sThreadEntry.th32ThreadID);

не помогло
делать привязки к хосту или к чему-то еще (guest-у) крайне не желательно, DLL должна быть автономной (на сколько это возможно)
если работа SetWindowsHookEx не таит для тебя никаких секретов, то поясни почему не работает мой вариант, 
хук должна ставит именно DLL и именно при аттаче.  

переделать внедрение DLL в процесс через SetWindowsHookEx вполне возможно(может и правильней) - это не противоречить преследуемой цели, однако присутствует спортивный интерес или если хотите вопрос о том на сколько хорошо мы понимаем как все это работает...
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Системное программирование и WinAPI"
Fixin
GremlinProg
xvr
feodorv
  • Большое количество информации и примеров с использованием функций WinAPI можно найти в MSDN
  • Описание сообщений, уведомлений и примеров с использованием компонент WinAPI (BUTTON, EDIT, STATIC, и т.п.), можно найти в MSDN Control Library
  • Непосредственно, перед созданием новой темы, проверьте заголовок и удостоверьтесь, что он отражает суть обсуждения.
  • После заполнения поля "Название темы", обратите внимание на наличие и содержание панели "А здесь смотрели?", возможно Ваш вопрос уже был решен.
  • Приводите часть кода, в которой предположительно находится проблема или ошибка.
  • Если указываете код, пользуйтесь тегами [code][/code], или их кнопочными аналогами.
  • Если вопрос решен, воспользуйтесь соответствующей ссылкой, расположенной напротив названия темы.
  • Один топик - один вопрос!
  • Перед тем как создать тему - прочтите это .

На данный раздел распространяются Правила форума и Правила раздела С++:Общие вопросы .


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Chipset, Step, Fixin, GremlinProg, xvr. feodorv.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Системное программирование и WinAPI | Следующая тема »


 




[ Время генерации скрипта: 0.0561 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.