利用两个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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • LCD1602接线图_srd继电器接线图

    LCD1602接线图_srd继电器接线图转载于:https://my.oschina.net/surenpi/blog/481697

    2022年9月2日
    3
  • 第一个模板类(templet<class elemType> class xxxxx)

    第一个模板类(templet<class elemType> class xxxxx)小弟是刚刚加入c++大队的,对c++中的基本知识只是稍微懂一点。今天在看《c++primer》中的模板类时,就将其中的程序在vs2008中写下,新建了Array.h和Array.cpp两个文件。主函数:Main.cpp1#include”stdafx.h”2#include<iostream>3#include”Array.h”45u…

    2022年5月19日
    51
  • lea指令!「建议收藏」

    lea指令!「建议收藏」
    最近在看linux-0.11内核,看到lea这个指令,google搜索了一下,转给大家,一起学习@!
     
    先看这个这个语法格式吧:
    对AT&T来说,寻址方式比较怪异,但又非常简洁,语法格式如下:segreg:base_address(offset_address,index,size) ;例子movl%eax,label1(,$2,$4)movl%ebx,(label2,$2,)movl%ecx,(%esp)
    其效果为

    2022年10月25日
    0
  • java先序中序后序遍历二叉树_二叉树的前序中序后续

    java先序中序后序遍历二叉树_二叉树的前序中序后续1.前序遍历    前序遍历(DLR,lchild,data,rchild),是二叉树遍历的一种,也叫做先根遍历、先序遍历、前序周游,可记做根左右。前序遍历首先访问根结点然后遍历左子树,最后遍历右子树。前序遍历首先访问根结点然后遍历左子树,最后遍历右子树。在遍历左、右子树时,仍然先访问根结点,然后遍历左子树,最后遍历右子树。若二叉树为空则结束返回,否则:(1)访问根结点。(2)前序遍历左子树。(3…

    2022年9月14日
    0
  • C++不确定行为

    C++不确定行为

    2022年1月22日
    36
  • 策略篇&访问策略 ❀ (5.4) 01. Explicit Web Proxy 显式web代理 ❀ 飞塔 (Fortinet) 防火墙

    策略篇&访问策略 ❀ (5.4) 01. Explicit Web Proxy 显式web代理 ❀ 飞塔 (Fortinet) 防火墙【简介】提供代理服务的计算机或其它类型的网络节点称为代理服务器,其具体过程为:客户端首先与代理服务器创建连接,接着发出一个对另外的目标服务器的文件或其它资源的连接请求,代理服务器通过与目标服务器连接或从缓存中取得请求的资源,并返回给客户端。通常在这个过程中,代理服务器可能改变客户端请求或服务器端响应的一些内容以满足各种代理需要。显式代理飞塔防火墙支持支持…

    2022年6月21日
    29

发表回复

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

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