龙人在线
about me

Arron

抛砖只为引玉(QQ长期隐身在线)
不能富贵难成大器皆因懒,
胸无大志庸庸碌碌只为闲。

这里是我平时收集的和写的一些东西,希望和大家一起共同进步!

无聊看看电影 边听音乐边看 有空多交流
Google_search
Google
hot
latest
photos
还你真实的开幕式!震撼美图[转]【连载】 央行今日发行600万张面额10元奥运纪念钞(组图) 巧遇日本妹妹海滩拍片片 诱不可挡超级丰胸大美人
links
龙人在线 >> 学习资料 >> Delphi专栏 >> 用hook实现dll注入详解

用hook实现dll注入详解

来源:来自网络 作者:不详 日期:2010-04-19 热度:

需要一个用来注入的dll(inject.dll)及一个调用程序(caller.exe)
流程:

caller.exe
procedure TestHook;
var pwnd,hChild, hwndInject hwnd;
msgtmsg;
begin
通过窗口标题用FindWindow找到要注入的程序的主窗口句柄pwnd
pwnd = findwindow('Progman',nil);
用FindwindowEx(hMain,0,nil,nil)找到要处理的子窗口句柄hChild
hChild = findWindowEx(pwnd,0,nil,nil);
用getwindowThreadProcessid(hChild,nil)找到要注入的线程
dwThreadID = getwindowThreadProcessid(hChild,nil);
调用 inject.dll的SetInjectHook方法
SetInjectHook(dwThreadID);
等待消息返回
getmessage(msg,0,0,0);
找到注入的窗口
hwndInject= findwindow(nil,'InjectForm');
发送控制消息,将目标窗体的句柄作为wparam,控制参数以lparam传入
sendMessage( hwndInject, wm_app,hChild,integer(true));
关闭注入的窗口
sendMessage( hwndInject,wm_close,0,0);
等待窗口关闭
sleep(500);
检查是否成功关闭
assert(not iswindow( hwndInject));
去掉挂钩
setDipsHook(0);
end;

下面说明 Inject.dll的SetInjectHook的具体操作
在全局定义以下变量
var
g_hhook Hhook=0;
g_dwThreadidInject dword=0;
g_hInjectfrmhwnd;


function SetInjectHook(dwThreadidDWORD)boolean;
begin
result = false;
如果线程标志为0则用于去掉钩子,否则进行动态库注入
if dwThreadid0 then
begin
assert(g_hhook=0);
保存当前线程的ID到 g_dwThreadidInject
g_dwThreadidInject = getCurrentThreadid;
下一个GetMessage的钩子到目标线程
GetMsgProc是在下面定义的一个函数,在第一次调用时将自定义的form在目标线程中创建出来
这样就能通过这个自定义的form对目标线程进行进程内控制了
g_hhook = setWindowsHookEx(wh_getMessage,GetMsgProc,hInstance,dwThreadid);
result = g_hhook null;
if result then
发一个空的信息以便于立即创建这个自定义form
result = postThreadMessage(dwThreadid, wm_Null,0,0);
等待半秒钟,以保证调用者可以找到这个刚创建的form
sleep(500);
end else
begin
assert(g_hhook0);
去掉钩子
result = unHookWindowsHookEx(g_hhook);
g_Hhook = 0;
end;
end;

定义一个全局的是否第一个消息的标志
var
fFirstTimeboolean = true;
这个函数用于在收到第一个消息时创建自定义窗体,以便于远程控制
function GetMsgProc(code Integer; wparam WPARAM; lparam LPARAM) LRESULT; stdcall;
begin
如果是第一次
if fFirstTime then
begin
fFirstTime = false;
创建窗体
InjectFrm = TinjectFrm.create(nil);
保存窗体句柄
g_hInjectfrm = InjectFrm.handle;
end;
调用默认处理,这一句可不能忘记
result = callNexthookEx(g_hhook,code,wparam,lparam);
end;
 

Tags: 用hook实现dll注入详解
广告位招租,广告代号:gg468
search
站内
advertise
Copyright © www.jx19.Com All rights reserved.