windows消息钩子一般都很熟悉了。它的用处很多,耳熟能详的就有——利用键盘钩子获取目标进程的键盘输入,从而获得各类密码以达到不可告人的目的。朋友想让他的软件不被别人的全局钩子监视,有没有办法实现呢?答案是肯定的,不过缺陷也是有的。 首先简单看看全局钩子如何注入别的进程。 消息钩子是由win32子系统提供,其核心部分通过ntusersetwindowshookex为用户提供了设置消息钩子的系统服务,用户通过它注册全局钩子。当系统获取某些事件,比如用户按键,键盘driver将扫描码等传入win32k的keyevent处理函数,处理函数判断有无相应hook,有则callhook。此时,系统取得hook对象信息,若目标进程没有装载对应的dll,则装载之(利用keusermodecallback"调用"用户例程,它与apc调用不同,它是仿制中断返回环境,其调用是"立即"性质的)。 进入用户态的kiusercallbackdispatcher后,kiusercallbackdispatcher根据传递的数据获取所需调用的函数、参数等,随后调用。针对上面的例子,为装载hook dll,得到调用的是loadlibraryexw,随后进入ldrloaddll,装载完毕后返回,后面的步骤就不叙述了。 从上面的讨论我们可以得出一个最简单的防侵入方案:在加载hook dll之前hook相应api使得加载失败,不过有一个缺陷:系统并不会因为一次的失败而放弃,每次有消息产生欲call hook时系统都会试图在你的进程加载dll,这对于性能有些微影响,不过应该感觉不到。剩下一个问题就是不是所有的loadlibraryexw都应拦截,这个容易解决,比如判断返回地址。下面给出一个例子片断,可以添加一些判断使得某些允许加载的hook dll被加载。 这里hook api使用了微软的detours库,可自行修改。 typedef hmodule (__stdcall *loadlib)( lpcwstr lpwlibfilename, handle hfile, dword dwflags);extern "c" { detour_trampoline(hmodule __stdcall real_loadlibraryexw( lpcwstr lpwlibfilename, handle hfile, dword dwflags), loadlibraryexw);}ulong user32 = 0;hmodule __stdcall mine_loadlibraryexw( lpcwstr lpwlibfilename, handle hfile, dword dwflags){ ulong addr; _a *** mov eax, [ebp+4] _a *** mov addr, eax if ((user32 & 0xffff0000) == (addr & 0xffff0000)) { return 0; } hmodule res = (loadlib(real_loadlibraryexw)) ( lpwlibfilename, hfile, dwflags); return res;}bool processattach(){ detourfunctionwithtrampoline((pbyte)real_loadlibraryexw, (pbyte)mine_loadlibraryexw); return true;}bool processdetach(){ detourremove((pbyte)real_loadlibraryexw, (pbyte)mine_loadlibraryexw); return true;}canti_hookapp::canti_hookapp() //在使用用户界面服务前调用processattach{ user32 = (ulong)getmodulehandle("user32.dll"); processattach();}
太阳星汉堡可以说是餐饮市场中很是不错的加盟品牌了,许多人都想要知道太阳星汉堡靠谱不?加盟条件有什么?其实太阳星汉堡加盟项目标条件并没有那么严格,相反照旧很简朴的,接下来我可觉得各人简朴的接管一下加盟项...
fastdomain(http://www.fastdomain.com/)主机是一个无限域名托管方案(unlimited domain hosting plan),通过fastdomain主机的ad...
本文目录一览: 1、睫毛增长液真的有用吗 - 百度 2、睫毛增长液真的有用吗? 3、睫毛增长液真的有效果吗?长期使用是否会对人体有危害? 4、睫毛增长液正确的涂抹方法 睫毛增长液真的有用...
经中央批准,我国监察委员会决议派遣观察小组赴湖北武汉,就下层反映的涉及到李文亮医师的相关难题作周全观察。...
尾牙节是福建地区的一个传统节日,尾牙节有许多传统习俗,每月的初二和十六都会有做牙活动,而十二月十六是一年之中的最后一次做牙,所以也被成为尾牙,外地人对福建尾牙不太了解,不知道尾牙的时间是什么时候,接下...
本文导读目录: 1、黑客怎样入门 2、黑客达人进 3、求一泡妞、恋爱的视频或音频教程!要有权威性的 4、有木有黑客视频教程-魔镜传说远控木马使用教程mjcs.wmv种子下载,谢恩公!...