摸索Detours 3:使用Detours 采用dll 方式进行Hook

本文介绍了如何使用Detours库通过DLL来实现Hook。首先,详细讲述了创建DLL项目的步骤和配置,接着展示了如何处理DLL_PROCESS_ATTACH和DLL_PROCESS_DETACH事件,以及定义和引入Hook的函数。然后,创建了一个简单的WPF客户端程序用于演示注入效果。最后,制作了一个“注射器”——一个C++控制台应用,利用DetourCreateProcessWithDllEx函数实现DLL注入,并展示了注入前后的效果和验证过程。
摘要由CSDN通过智能技术生成

1.准备工作

新建一个DLL项目,当然 依旧是要按照前面所说的配置一下包含目录库目录。然后就可以开始了。

2.开始,注入用Dll

使用DLL进行Hook的时候,主要处理DLL_PROCESS_ATTACH和DLL_PROCESS_DETACH 这两项,在编写相应的处理代码之前,当然是要先定义和引入需要Hook的函数,和替换的函数,如下:

static int (WINAPI* OldMesssageBoxW)(_In_opt_ HWND hWnd,	_In_opt_ LPCWSTR lpText,_In_opt_ LPCWSTR lpCaption,_In_ UINT uType) = MessageBoxW;
static int (WINAPI* OldMesssageBoxA)(_In_opt_ HWND hWnd,_In_opt_ LPCSTR lpText,	_In_opt_ LPCSTR lpCaption,	_In_ UINT uType) = MessageBoxA;
static int WINAPI NewMesssageBoxW(_In_opt_ HWND hWnd,	_In_opt_ LPCWSTR lpText,	_In_opt_ LPCWSTR lpCaption,	_In_ UINT uType)
{
	
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值