Форум программистов, компьютерный форум, киберфорум
C/C++: WinAPI
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
0 / 0 / 0
Регистрация: 15.11.2012
Сообщений: 12

Ловушка / Hook крашит приложения (WH_CBT/HCBT_CREATEWND)

18.05.2015, 20:10. Показов 2334. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Отрывисто изучаю WinApi, наткнувшись на такую технологию как ловушки, решил реализовать следующую задачу (придуманную на ходу).
Задача: отлавливать создание окна с определенным заранее известным именем класса и скрывать его (создавать свернутым, создавать за границами экрана, изменять размер создаваемого окна или любым другим методом). Реализовать путём установки глобальной (локальной) ловушку (hook) (из dll) типа WH_CBT с отслеживанием HCBT_CREATEWND.
В качестве объекта для тренировки было создано минимальное приложение на delphi, состоящая из двух форм и кнопки. На главной форме приложения расположена кнопка, которая вызывает создание дополнительного окна, на которое и должен сработать хук. Информация SPY++: Заголовок окна: Form1/Form2 Имя класса: TForm1/TForm2
Button1Click

Delphi
1
2
3
4
5
procedure TForm1.Button1Click(Sender: TObject);
  begin
    Application.CreateForm(TForm2, Form2);
    Unit2.Form2.Show();
  end;


Методом чтения множества информации по hook'ам был написан (скопирован) следующий код. Для dll:
DLL

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# include <windows.h>
 
extern "C" __declspec(dllexport) LRESULT CALLBACK CBTProc(int nCode, WPARAM wParam, LPARAM lParam){
    if (nCode < 0)
        return CallNextHookEx(0, nCode, wParam, lParam);
 
    return CallNextHookEx(0, nCode, wParam, lParam);
 
    switch (nCode){
        case HCBT_ACTIVATE:
            break;
 
        case HCBT_CLICKSKIPPED:
            break;
 
        case HCBT_CREATEWND:{           
            char hBuf[255];
            CBT_CREATEWND *WindowsCreatCtrust = (CBT_CREATEWND *) lParam;
            HWND hWnd = (HWND) wParam;
            GetClassName(hWnd, (LPWSTR) hBuf, 255);
 
            if ((lstrcmp(WindowsCreatCtrust->lpcs->lpszClass, L"TForm2") == 0)){
                // Подаём знак
                                MessageBeep(MB_ICONASTERISK);
                MessageBoxW(NULL, (LPCWSTR) hBuf, L"ClassName", NULL);
            }
            break;
        }
 
        case HCBT_DESTROYWND:
            break;
 
        case HCBT_KEYSKIPPED:
            break;
 
        case HCBT_MINMAX:
            break;
 
        case HCBT_MOVESIZE:
            break;
 
        case HCBT_QS:
            break;
 
        case HCBT_SETFOCUS:
            break;
 
        case HCBT_SYSCOMMAND:
            break;
 
        default: break;
    }
 
    return CallNextHookEx(0, nCode, wParam, lParam);
}

Для основной программы, в которой происходит установка хука.
Main

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# include <stdio.h>
# include <Windows.h>
 
int main(){
    HMODULE hLib = LoadLibrary(L"HookDLL.dll");
    
    if (!hLib)
        return -1;
 
    HOOKPROC hHookProc = (HOOKPROC) GetProcAddress(hLib, "_CBTProc@12");
 
    if (!hHookProc)
        return -1;
 
    HHOOK hHook = SetWindowsHookEx(WH_CBT, hHookProc, hLib, 0);
    
    if (!hHook)
        return -1;
 
    printf("Program successfully hooked.\nPress enter to unhook the function and stop the program.\n");
    system("pause");
    
        FreeLibrary(hLib);
    UnhookWindowsHookEx(hHook);
 
    return 0;
}


Теперь о главном, проблема состоит в том, что при отладке приложения, после момента выполнения команды установки хука (SetWindowsHookEx), любое действие с тестовым приложение (Form 1), будь то его сворачивание, клик по кнопке на главной форме для открытия дополнительной формы и т.д. приводит к ошибкам в памяти приложения (скриншоты ниже). Прошу помощи в устранении проблемы и направлении на путь истинный Заранее благодарю.
Скриншоты ошибок
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.05.2015, 20:10
Ответы с готовыми решениями:

В чем преимущество trampoline hook над обычным hook?
Объясните пожалуйста в чем преимущество trampoline hook и hook? Никак не могу понять

WH_CBT и Mozilla FireFox
Доброго времени суток Ставлю хук WH_CBT на HCBT_ACTIVATE (код представлен ниже). Функцией SetHook() в главной программе устанавливаю...

wParam у HCBT_CREATEWND и HCBT_DESTROYWND не совпадают
Здравствуйте, уважаемые гуру. У меня следующий вопрос, написал длл, в которой есть функция CBTProc, так вот при обработке событий...

5
1130 / 789 / 232
Регистрация: 12.04.2010
Сообщений: 2,012
18.05.2015, 22:44
Цитата Сообщение от _NeRoN_ Посмотреть сообщение
FreeLibrary(hLib);
UnhookWindowsHookEx(hHook);
Может быть следует, наоборот, сначала unhook. А то программа пытается обратиться к функции уже освобождённой библиотеки. (Между вызовами FreeLibrary() и unhook.)
FreeLibrary Function . " ... the module is unmapped from the address space of the calling process and the handle is no longer valid."
1
0 / 0 / 0
Регистрация: 15.11.2012
Сообщений: 12
19.05.2015, 12:34  [ТС]
Цитата Сообщение от Alex5 Посмотреть сообщение
Может быть следует, наоборот, сначала unhook. А то программа пытается обратиться к функции уже освобождённой библиотеки. (Между вызовами FreeLibrary() и unhook.)
FreeLibrary Function . " ... the module is unmapped from the address space of the calling process and the handle is no longer valid."
Благодарю за то, что так быстро откликнулись, но, к сожалению, результат аналогичный, что с использованием FreeLibrary() после UnhookWindowsHookEx(), что и без этой функции вовсе.

Для чистоты эксперимента решил проверить работу хука на виртуальной машине (чистая windows 7 x32) на том же приложении delphi. Результат такой, после выполнения основного кода программы установки хука (до момента паузы, в ожидании нажатия кнопки), когда уже точно выполнилась команда SetWindowsHookEx, с тестовым приложением (как и со всеми другими) на delphi можно было спокойно работать, скрывать, перемещать и т.д., при клике на кнопку корректно, без каких-либо ошибок, открывалась дополнительная форма, но при этом установленный хук никак не реагировал на все эти действия, хотя должна была выполняться команда MessageBoxW(NULL, (LPCWSTR) hBuf, L"ClassName", NULL); Попытка переместить команду создания окна с сообщением (естественно с обычным текстом) в самое начало функции CBTProc, сразу за условие if (nCode < 0), чтобы убедится в отсутствии условий мешающих выводу сообщения, также принесло успеха. В общем, хотелось бы услышать другие варианты.

Кстати, ещё додумался проверить подгрузку dll при помощи ПО Process Hacker, dll найти не удалось.
Скриншот
0
Ушел с форума
Эксперт С++
 Аватар для Убежденный
16481 / 7444 / 1187
Регистрация: 02.05.2013
Сообщений: 11,616
Записей в блоге: 1
19.05.2015, 17:57
Цитата Сообщение от _NeRoN_ Посмотреть сообщение
Теперь о главном, проблема состоит в том, что при отладке приложения, после момента выполнения команды установки хука (SetWindowsHookEx), любое действие с тестовым приложение (Form 1), будь то его сворачивание, клик по кнопке на главной форме для открытия дополнительной формы и т.д. приводит к ошибкам в памяти приложения (скриншоты ниже).
Могу посоветовать лишь одно - осваивайте отладчик,
подключайтесь к упавшему процессу и смотрите, где упало.
1
0 / 0 / 0
Регистрация: 15.11.2012
Сообщений: 12
20.05.2015, 12:27  [ТС]
Цитата Сообщение от Убежденный Посмотреть сообщение
Могу посоветовать лишь одно - осваивайте отладчик,
подключайтесь к упавшему процессу и смотрите, где упало.
Навык отладки приложений является несомненно нужным, попытаюсь разобраться. Если у кого-нибудь есть конструктивные предложения по сложившейся проблеме, пишите, периодически проверяю тему.
0
1130 / 789 / 232
Регистрация: 12.04.2010
Сообщений: 2,012
21.05.2015, 00:38
del

Добавлено через 3 минуты
Цитата Сообщение от _NeRoN_ Посмотреть сообщение
любое действие с тестовым приложение (Form 1), ... приводит к ошибкам в памяти приложения
Цитата Сообщение от _NeRoN_ Посмотреть сообщение
при клике на кнопку корректно, без каких-либо ошибок, открывалась дополнительная форма
Так как же обстоит дело? Форма откр. с ошибкой или без?

Добавлено через 16 минут
Цитата Сообщение от _NeRoN_ Посмотреть сообщение
C++
1
2
char hBuf[255];
 GetClassName(hWnd, (LPWSTR) hBuf, 255);
_NeRoN_, зачем Вы здесь написали (LPWSTR)?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.05.2015, 00:38
Помогаю со студенческими работами здесь

CBT хук, HCBT_CREATEWND для одного окна выполняется не однократно
Здравствуйте возникла проблема при мониторинге открытия окон. При установке хука CBT и кода HCBT_CREATEWND блок повторяется не однократно: ...

Ловушка мыши
Всем привет, собственно пытаюсь написать программу для &quot;ловления&quot; координат курсора, при щелчке на правую кнопку мыши. Все сделал, кроме...

Ловушка delphi
Помогите пожалуйста! Не могу понять в чем проблема. library syshook; uses windows, messages,ComObj,SysUtils; {$R *.res} ...

SNMP ловушка
Всем привет! Есть у кого-нибудь рабочий пример кода SNMP ловушки? То есть устройство при возникновении ошибок выдает SNMP Trap на...

Shutdown ловушка c#
Всем доброго дня. Есть ли возможность отследить внезапное завершение процесса (убийство процесса пользователем, через диспетчер задач), и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru