任务管理器Hook

这些天学了一些关于钩子的知识,于是动手写了个程序实践一番

功能是进程保护,防止进程被windows任务管理器结束

当然 ,也仅仅只针对任务管理器做了实现

不多说, 一边贴代码一遍解释原理 :

首先写个DLL,其中放置一段共享数据,用来存放要保护的进程的ID

#pragma data_seg("ShareData")
UINT ProtectedId = NULL;
#pragma data_seg()
#pragma comment(linker, "/SECTION:ShareData,RWS")

RWS之前不能有空格,不然会编译出错,为此还纠结了一阵子


然后提供2个接口

//export.h
#pragma once

extern "C" __declspec(dllexport) void SetHook(bool);
extern "C" __declspec(dllexport) void SetPID(DWORD PID);

//dllmain.cpp

void SetPID(DWORD PID)
{
    g_ProtectPid = PID;
}

void SetHook(bool bSet)
{
    switch(bSet)
    {
    case true:
        if (g_ProtectPid == NULL)
        {
            MSG("请设置要保护的进程ID");
            return;
        }
        if(g_hHook == NULL)
        {
            g_hHook = SetWindowsHookEx(WH_GETMESSAGE, HookProc, g_hMod, 0);
        }
        break;
    case false:
        if(g_hHook != NULL)
        {
            UnhookWindowsHookEx(g_hHook);
            g_hHook = NULL;
        }
        break;
    }
}

再就是一个Hoo
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值