利用两个dll实现全局钩子

利用两个dll实现全局钩子全局消息钩子的钩子函数一定要再dll中,然后启动安装钩子不能在dll中,要是我想在程序开始时安装钩子怎么办。很简单利用两个钩子就行了,只要安装钩子和钩子函数不在同一个dll就行了。下面请看案例(编译

大家好,又见面了,我是你们的朋友全栈君。

全局消息钩子的钩子函数一定要再dll中,然后启动安装钩子不能在dll中,要是我想在程序开始时安装钩子怎么办。很简单利用两个钩子就行了,只要安装钩子和钩子函数不在同一个dll就行了。

下面请看案例(编译

编译环境: vs2010 多字节  已在window7 32位测试通过

//mouseHook.cpp 钩子函数所在dll
#include <windows.h>

// a sample exported function
#define DEF_PROCESS_NAME "winmine.exe"
#define WIDTH 32
#define HEIGHT 24

HINSTANCE g_hInstance=NULL;
HHOOK g_hHook=NULL;


//窗口坐标转化为雷区坐标
VOID windowPosChangeToMinePos(POINT * pt){
    int y = (pt->x-10)/16+1;
    int x = (pt->y-55)/16+1;
    pt->x = x;
    pt->y = y;
}

BOOL first = TRUE;

BYTE rects[HEIGHT][WIDTH];
HWND window = NULL;
// a sample exported function
//LRESULT是一个数据类型,指的是从窗口程序或者回调函数返回的32位值
//lParam wParam 是宏定义,一般在消息函数中带着两个类型的参数,通常用来存储窗口消息的参数。wParam用来存储小段消息,如标志。lParam 通常用于存储消息所需的对象。
LRESULT CALLBACK MouseProc(int nCode,WPARAM wParam,LPARAM lParam)
{
    char szPath[MAX_PATH]={0,};
    char *p=NULL;
    HWND hWnd;
    int x;
    int y;
    char  xs[MAX_PATH] = {0,};
    char  ys[MAX_PATH] = {0,};
    int i,j;
    byte * temp;
    int tempInt;
    char  byteTemp[2] = {0,};
    if (nCode>=0)
    {
        //0=key press,1=key release
        if (wParam == WM_MOUSEMOVE )//释放键盘按键时
        {
            GetModuleFileNameA(NULL,szPath,MAX_PATH);
            p=strrchr(szPath,'\\');//查找字符在指定字符串中从左面开始的最后一次出现的位置
            
            //比较当前进程名称,若为notepad.exe,则消息不会传递给应用程序(或下一个“钩子”)
            if (!_stricmp(p+1,DEF_PROCESS_NAME)){
                //SetWindowTextA(hWnd,"saolei");
                LPMOUSEHOOKSTRUCT lpMouse=(MOUSEHOOKSTRUCT FAR*)lParam;
                if (first==TRUE)

                {    
                    window = lpMouse->hwnd;
                    first=FALSE;
                }
            
                
                ScreenToClient(lpMouse->hwnd,&lpMouse->pt);
                windowPosChangeToMinePos(&lpMouse->pt);
                x = lpMouse->pt.x;
                y =lpMouse->pt.y;
                if(x>0&&y>0&&window==lpMouse->hwnd){
                    temp= (byte *)0x01005361;
                    for (i=0;i<HEIGHT;i++)
                    {
                        for (j=0;j<WIDTH;j++)
                        {    
                            rects[i][j] = *(temp+i*WIDTH+j);
                        }
                    }
                 tempInt =  rects[x-1][y-1];
                //itoa(tempInt,xs,16);
                /* itoa(x,xs,16);
                itoa(y,ys,10);
                strcat(xs,",");
                strcat(xs,ys);*/
                /*    strcat(xs,",");
                itoa(x,ys,10);
                strcat(xs,ys);
                strcat(xs,",");
                itoa(y,ys,10);
                strcat(xs,ys);*/
                /* itoa((int)lpMouse->hwnd,xs,16);
                 SetWindowTextA(lpMouse->hwnd,xs);*/
                 if (tempInt==0x8f)
                 {
                 SetWindowTextA(lpMouse->hwnd,"扫雷");
                 }
                 else
                 SetWindowTextA(lpMouse->hwnd,"扫蕾");
                
                }
                
                }
        }

    }

    //若非notepad.exe,则调用CallNextHookEx()函数,将消息传递给应用程序(或下一个“钩子”)。
    return CallNextHookEx(g_hHook,nCode,wParam,lParam);

}
LPDWORD lpdwProcessId;
BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
{
    switch (fdwReason)
    {
    case DLL_PROCESS_ATTACH:
        g_hInstance = hinstDLL;
        break;

    case DLL_PROCESS_DETACH:
        break;

    case DLL_THREAD_ATTACH:
    
        // attach to thread
        break;

    case DLL_THREAD_DETACH:

        // detach from thread
        break;
    }
    return TRUE; // succesful
}

#ifdef __cplusplus
extern "C"
{
#endif


    __declspec(dllexport) void HookStart()
    {
        //钩子类型、回调函数地址、实例句柄、线程ID
        g_hHook=SetWindowsHookEx(WH_MOUSE,MouseProc,g_hInstance,0);
    }

    __declspec(dllexport) void HookStop()
    {
        if(g_hHook)
        {
            UnhookWindowsHookEx(g_hHook);
            g_hHook=NULL;
        }
    }

#ifdef __cplusplus
}
#endif
//middleObject.cpp  生成dll 在dll被加载启动安装钩子
#include <windows.h>
#include <stdio.h>
#include <conio.h>

#define DEF_DLL_NAME "mouseHook.dll"
#define DEF_HOOKSTART "HookStart"
#define DEF_HOOKSTOP "HookStop"

typedef void (*PFN_HOOKSTART)();
typedef void (*PFN_HOOKSTOP)();
HMODULE hDll=NULL;
PFN_HOOKSTART HookStart=NULL;
PFN_HOOKSTOP HookStop=NULL;

BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
{
    switch (fdwReason)
    {
    case DLL_PROCESS_ATTACH:

    

        //加载KeyHook.dll
        hDll=LoadLibraryA(DEF_DLL_NAME);

        //获取导出函数地址
        HookStart=(PFN_HOOKSTART)GetProcAddress(hDll,DEF_HOOKSTART);
    

        //开始钩取
        HookStart();

        break;

    case DLL_PROCESS_DETACH:
        HookStop=(PFN_HOOKSTART)GetProcAddress(hDll,DEF_HOOKSTOP);
        HookStop();
        // detach from process
        break;

    case DLL_THREAD_ATTACH:

        // attach to thread
        break;

    case DLL_THREAD_DETACH:

        // detach from thread
        break;
    }
    return TRUE; // succesful
}
#ifdef __cplusplus
extern "C"
{
#endif

    __declspec(dllexport) void dummy()
    {
        
    }


#ifdef __cplusplus
}
#endif

 

只要把middleObject.dll加载就可以安装消息钩子了

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155408.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Django(39)使用redis配置缓存[通俗易懂]

    Django(39)使用redis配置缓存[通俗易懂]前言动态网站的基本权衡是,它们是动态的。每次用户请求页面时,Web服务器都会进行各种计算-从数据库查询到模板呈现再到业务逻辑-以创建站点访问者看到的页面。从处理开销的角度来看,这比标准的文件

    2022年8月7日
    5
  • hi3516dv300芯片手册_hi3518ev300

    hi3516dv300芯片手册_hi3518ev300基于Hi3516DV300的嵌入式入门演练(上)基于Hi3516DV300的嵌入式入门演练(下)文章目录信息前言勉励1开始之前1.1操作系统与开发准备1.2推荐的书籍1.3书本之外2最小系统环境的搭建流程2.1VMWareWorkstationPlayer和Kubuntu2.1.1创建虚拟机2.1.2Kubuntu系统安装2.2搭建Hi3516DV300的开发环境2.2.1工具链安装与开发环境配置2.2.2展开SDK2.3U-Boot的编译2.4Kernel的编译2.5根

    2022年9月24日
    2
  • pycharm2021.5.2激活码永久【在线注册码/序列号/破解码】

    pycharm2021.5.2激活码永久【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    59
  • 报错解决:Downloading VS Code Server failed. Please try again later.

    报错解决:Downloading VS Code Server failed. Please try again later.之前写过教程:Windows下使用VSCode远程SSH连接Linux服务器进行开发vscode使用ssh密钥登录远程Linux–vscoderemotelinuxsshkey

    2022年5月27日
    225
  • random生成随机整数 python_python中的random函数

    random生成随机整数 python_python中的random函数在Python中用于生成随机数的模块是random,在使用前需要import.random.random():生成一个0-1之间的随机浮点数importrandoms=random.random()srandom.uniform(a,b):生成[a,b]之间的浮点数importrandoma=3.0b=6.0s=random.uniform(a,b)srandom.randint(a,b):生成[a,b]之间的整.

    2022年10月4日
    2
  • RBF神经网络实验原理_神经网络多元拟合

    RBF神经网络实验原理_神经网络多元拟合RBF神经网络及拟合实例RBF神经网络介绍RBF神经网络结构RBF神经网络算法RBF神经网络逼近算法采用RBF神经网络逼近非线性函数神经网络逼近结果代码如下RBF神经网络介绍RBF神经网络结构径向基函数(RadialBasisFunction,RBF)神经网络是一种单隐含层的三层前馈神经网络,网络结构如下图所示RBF神经网络模拟了人脑中局部调整,相互覆盖接受域(或者说感受域,ReceptiveField)的神经网络结构。与BP神经网络相同,研究人员已经证明RBF神经网络能够以任何精度逼近任

    2025年6月1日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号