利用两个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)
上一篇 2022年7月2日 上午8:16
下一篇 2022年7月2日 上午8:16


相关推荐

  • Kimi k2性能被赞超越 GPT-5,月之暗面再获数亿美元重磅融资

    Kimi k2性能被赞超越 GPT-5,月之暗面再获数亿美元重磅融资

    2026年3月12日
    2
  • SPEL表达式_什么是EL表达式

    SPEL表达式_什么是EL表达式前言最近在搞项目的自定义流程,主流的流程引擎flowable不能很好的支撑业务需求,再考虑到后期的拓展,部门经理说让自己搞一套。这里玩SpEL表达式是为了解决业务流向判断的[条件表达式]问题仿佛记得java是有自定义表达式的,昨儿翻阅书记目录却没有找到,可能是我记错了吧(如果有知道的朋友请留言)。那就直接用SpEL表达式吧,早上查阅了下网上的资料,下面这篇文章挺全的,遂转载一下(copy过来添加了锚点定位,方便以后查阅)8.1介绍8.2功能概述8.3使用Spring的表达接口表达式

    2025年11月1日
    6
  • 定时备份数据库的存储过程.sql

    定时备份数据库的存储过程.sql

    2021年4月25日
    149
  • 封装是怎么实现的_ad13怎么添加封装

    封装是怎么实现的_ad13怎么添加封装1.封装的概念(1)将东西包装在一起,然后以新的完整的形式呈现出来(即将属性和方法封装到类里面,通过添加访问修饰符来限制访问权限,以达到信息隐藏的目的)(2)信息隐藏:隐藏对象的实现细节,不让外部

    2022年8月1日
    7
  • maven中的Exclusions标签详解

    maven中的Exclusions标签详解解释 exclusion 标签 1 这个标签的作用是排除关联依赖的引入 因为 maven 的 pom 依赖其中有一点是将关联的依赖全都引入进来 2 这个标签在这的作用就是如果关联的依赖和引入的其他依赖可能存在冲突 就必须将关联的依赖排除掉 所以就用这个标签 3 另外这个 s 的 大家应该也明白 就是可以包含多个吗 依赖关系 Project A gt Project B gt Project C 但是 Project A 不依赖 Project C 在 Project A 中的 POM xml 应该进行

    2026年3月17日
    1
  • Android中bindService基本使用方法概述

    Android中bindService基本使用方法概述Android中有两种主要方式使用Service,通过调用Context的startService方法或调用Context的bindService方法,本文只探讨纯bindService的使用,不涉及任何startService方法调用的情况。bindService启动服务的特点相比于用startService启动的Service,bindService启动的服务具有如下特点: 

    2022年5月4日
    55

发表回复

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

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