zoukankan      html  css  js  c++  java
  • mfc HackerTools全局钩子

    钩子英文名叫Hook,是一种截获windows系统中某应用程序或者所有进程的消息的一种技术。

    如在键盘中按下一键,操作系统将收到键按下消息,把消息放入消息队列,然后消息队列对消息进行派发,发给相应的应用程序,经过应用程序处理后发给操作系统,操作系统再调用相应的应用程序的创建的窗口过程。

    SetWindowsHookEx安装一个应用程序定义的钩子过程,并把创建的钩子过程放在钩子链中,可以安装多个钩子,多个钩子就形成了钩子链,最后安装的钩子总是在最前面。

    LRESULT CALLBACK MouseProc(int nCode, WPARAM wParam, LPARAM lParam);形参含义并不是都一样的,不同钩子过程形参表示的意义不一样。

    BOOL UnhookWindowsHookEx(HHOOK hhk);此API的功能是把SetWindowsHookEx创建的钩子从钩子链中移除。形参是SetWindowsHookEx返回的钩子句柄。

    全局钩子必须在DLL上实现,钩子过程不能在本进程代码中实现,所以先得写一个DLL。

    #include "stdafx.h"
    
    extern HMODULE g_hDllMoudle;    //dll的句柄
    //共享内存
    #pragma data_seg("mydata")    //创建一个名为mydata的数据段
        HHOOK g_hHook = NULL;
    #pragma data_seg()
    #pragma comment(linker,"/SECTION:mydata,RWS")  //把mydata数据段设置为可读可写可共享
    
    
    
    
    extern "C" _declspec(dllexport)
    //钩子回调函数
    LRESULT GetMsgProc(int code, WPARAM wParam, LPARAM lParam)
    {
        MessageBoxA(0, "弹窗", "你中毒了", 0);
        return CallNextHookEx(g_hHook, code, wParam, lParam);
    }
    
    extern "C" _declspec(dllexport)
    //设置全局钩子
    BOOL SetGlobalHook()
    {
        g_hHook = SetWindowsHookEx(WH_GETMESSAGE, (HOOKPROC)GetMsgProc, g_hDllMoudle, 0);
        if (g_hHook==NULL)
        {
            return FALSE;
        }
        return TRUE;
    }
    
    extern "C" _declspec(dllexport)
    //卸载全局钩子
    BOOL UnSetGlobalHook() 
    {
        if (g_hHook) 
        {
            UnhookWindowsHookEx(g_hHook);
        }
        return TRUE;
    }
    调用DLL中的钩子
    void CInject::SetGlobalHook()
    {
        //定义函数指针和函数指针变量
        typedef BOOL(*typedef_SetGlobalHook)();
        typedef_SetGlobalHook fnSetGlobalHook = NULL;
        //获取DLL加载基址
        m_hDll = LoadLibrary(m_Edit);
        if (m_hDll)
        {
            m_TipMsg += L"DLL加载成功
    ";
        }
        else
        {
            m_TipMsg += L"DLL加载失败
    ";
        }
    
        //获取函数地址 给函数指针变量赋值
        fnSetGlobalHook = (typedef_SetGlobalHook)GetProcAddress(m_hDll, "SetGlobalHook");
        if (fnSetGlobalHook)
        {
            m_TipMsg += L"加载函数地址成功
    ";
        }
        else
        {
            m_TipMsg += L"加载函数地址失败
    ";
        }
        //设置全局钩子
        BOOL bRet = fnSetGlobalHook();
    
            
        if (bRet)
        {
            m_TipMsg += L"设置全局钩子成功 开始无限弹框
    ";
        }
        else
        {
            m_TipMsg += L"设置全局钩子失败
    ";
        }
    
        UpdateData(FALSE);
    
    }
  • 相关阅读:
    [ActionScript 3.0] AS3.0将图像的Alpha通道转换为黑白图像(复制通道方式)
    [ActionScript 3.0] 喷泉效果
    [ActionScript 3.0] AS3.0 下雨及涟漪效果
    [ActionScript 3.0] AS3.0 复制xml,并赋值
    [ActionScript 3.0] AS3.0 火焰效果
    [ActionScript 3.0] AS3.0 烟雾粒子效果
    Java学习之==>面向对象编程 Part1
    Java学习之==>int和Integer的区别和联系
    Java学习之==>数组【array】
    Java学习之==>条件判断、循环控制
  • 原文地址:https://www.cnblogs.com/zebra-bin/p/13201622.html
Copyright © 2011-2022 走看看