[C#]利用EasyHook创建安装本地钩子[教程翻译+理解]
来源:互联网 发布:网易云音乐数据库 编辑:程序博客网 时间:2024/06/11 19:20
原教程:EasyHook - Creating a local hook 原demo源码:github
本地钩子只能钩住你代码运行的所在的进程
导入EasyHook:
1.用新建/打开一个C#项目
2.右键你的项目解决方案-—>管理解决方案的NuGet程序包..——>浏览——>搜索EasyHook——>安装
3.新建hook.cs源代码文件
使用EasyHook的local Hook简要步骤如下:
1.得到你想要钩住的原生函数的地址:
使用LocalHook.GetProcAddress
EasyHook.LocalHook.GetProcAddress("user32.dll", "MessageBeep") //MessageBeep为要钩住的参数名 user32.dll
2.定义一个delegate类型,它必须与你想钩住的原生函数的调用惯例 和参数个数相同:
(调用惯例就是:__stdcall/__cdecl/__pascal/__fastcall/等等)
可去MSDN查阅MessageBeep()相关信息
[UnmanagedFunctionPointer(CallingConvention.StdCall, SetLastError = true)] [return: MarshalAs(UnmanagedType.Bool)] delegate bool MessageBeepDelegate(uint uType);
3.写一个你想要代替原生函数的新的处理方法:
static bool MessageBeepHook(uint uType) { Console.Write("NoBeep!"); return false; }
4.建立和安装钩子:
1.建立本地钩子事例调用LocalHook.Create,传入原生函数地址与连接了新的处理方法的委任函数
var hook = EasyHook.LocalHook.Create( EasyHook.LocalHook.GetProcAddress("user32.dll", "MessageBeep"), new MessageBeepDelegate(MessageBeepHook), null);
2.在当前线程上安装钩子(0表示当前线程)
hook.ThreadACL.SetInclusiveACL(new int[] { 0 });
5.卸载钩子
hook.ThreadACL.SetExclusiveACL(new int[] { 0 });hook.Dispose();EasyHook.LocalHook.Release();
阅读全文
0 0
- [C#]利用EasyHook创建安装本地钩子[教程翻译+理解]
- EasyHook库系列使用教程之二插入钩子接口
- EasyHook库系列使用教程之三插入钩子示例
- EasyHook库系列使用教程之四钩子的启动与停止
- EasyHook库系列使用教程之五全局ACL和本地ACL
- EasyHook
- 利用钩子技术控制进程创建
- 利用钩子技术控制进程创建
- 利用钩子技术控制进程创建
- 利用钩子技术控制进程创建
- 利用钩子技术控制进程创建
- 利用钩子技术控制进程创建
- 利用安装光盘创建本地 yum 源补装 RPM 软件包
- 利用安装光盘创建本地 yum 源补装 RPM 软件包
- 利用安装光盘创建本地 yum 源补装 RPM 软件包
- EasyHook 中部分函数的实现分析—-申请钩子
- Ember 翻译——教程四:模型钩子
- 本地安装Magento教程
- Linux 计划任务 at
- 安卓7.1中添加服务,内核log出现Service xxx does not have a SELinux domain defined【转】
- To The Max
- apache2 服务器模块文件配置
- JDK各个版本的新特性jdk1.5-jdk1.8
- [C#]利用EasyHook创建安装本地钩子[教程翻译+理解]
- 转型
- [LeetCode]Integer to Roman
- 刚学if else 用的不好 各位大神不要见笑
- 移动端多指触屏事件兼容
- 在centos环境下部署yara
- HttpClient发送HTTP请求
- Battle test(Locust and Apache Bench)
- chartjs图标插件