防止消息钩子攻击的有效措施
>首页 -> 社会专题 -> 硬件网络 2010-07-08 来源: 作者: 【】 浏览:521

首先简单看看全局钩子如何注入别的进程。

消息钩子是由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;

_asm mov eax, [ebp+4]

_asm 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();      

您看到此篇文章时的感受是:
Tags: 责任编辑:佚名
免责申明: 除原创及很少部分因网文图片遗失而补存外,本站不存储任何有版权的内容。你看到的文章和信息及网址索引均由机器采集自互联网,由于时间不同,内容可能完全不同,请勿拿本网内容及网址索引用于交易及作为事实依据,仅限参考,不会自行判断者请勿接受本站信息,本网转载,并不意味着赞同其观点或证实其内容的真实性.如涉及版权等问题,请立即联系管理员,我们会予以更改或删除,保证您的权利.对使用本网站信息和服务所引起的后果,本网站不作任何承诺.
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论:0条】 【关闭】 【返回顶部
更多
上一篇不安杀毒软件也安全的方法 下一篇叮叮办公软件对局域网影响
密码: (新用户注册)

最新文章

图片主题

热门文章

推荐文章

相关文章

便民服务

手机扫描

空间赞助

快速互动

论坛互动
讨论留言

有事联系

有哪个那个什么的,赶紧点这里给DOVE发消息

统计联系

MAIL:gnlt@Dovechina.com
正在线上:1360

版权与建议

任何你想说的