分享
 
 
 

用hook实现dll注入详解

王朝delphi·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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

流程:

caller.exe

procedure TestHook;

var pwnd,hChild, hwndInject :hwnd;

msg:tmsg;

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_hInjectfrm:hwnd;

function SetInjectHook(dwThreadid:DWORD):boolean;

begin

result := false;

//如果线程标志为0则用于去掉钩子,否则进行动态库注入

if dwThreadid<>0 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_hhook<>0);

//去掉钩子

result := unHookWindowsHookEx(g_hhook);

g_Hhook := 0;

end;

end;

//定义一个全局的是否第一个消息的标志

var

fFirstTime:boolean = 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;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有