IAT HOOK 实现进程保护

Posted on 2009-05-13 14:42  Samson小天  阅读(4461)  评论(2编辑  收藏  举报

这两天学校图书馆安了新的管理系统,把我一些常用的软件都禁用了。让我非常郁闷,用Ice Sword把管理软件结束进程的话,又会被服务端禁止上网。无奈之下研究了下如何保护进程。

多天的学习,发现进程保护有几种方法,一个是最简单的RING 3下的IAT HOOK,我们将系统的IAT表中的OpenProcess函数Hook住,就能实现对特定的进程保护起来。

这种方法只能对任务管理器和调用OpenProcess获取进程句柄的程序有效。如果是XP或者VISTA下的taskkill命令,这种方法是防不住的。这种情况下要用SSDT HOOK才行。SSDT只给大家提一下,本文并不深究,因为SSDT HOOK要驱动参与的。

那么现在我们来看看任务管理器是怎么结束进程的——Ring3下有一个函数叫TerminateProcess(HANDLE hProc , UINT uExitCode),后面那个参数无所谓,是退出时的返回值,前面那个参数是要结束的进程的句柄。

那么怎么获得这个进程的句柄呢?大多数程序是通过HANDLE OpenProcess(DWORD dwDesiredAccess,BOOL bInheritHandle,DWORD dwProcessId),第二个参数没什么所谓,指的是句柄是否允许继承,没关系。第三个参数指的是要结束的进程的PID值。第一个参数指的是你希望获得的句柄具有哪些权限,也就是说当dwDesiredAccess & PROCESS_TERMINATE != 0时,这个句柄是具有结束进程权限的。

明白了这些后,我们可以用一个钩子,HOOKOpenProcess,我们判断调用方的第三个参数是不是我们的PID,如果不是就不用管,如果是,那么判断第一个参数是不是具有结束进程的权限,如果有,那么我们返回NULL,严谨一点还可以通过SetLastError函数设置一个错误信息。

程序截图:


接下来介绍下简单的源代码:

源代码分为2部分,程序采用Visual studio 2008,MFC、WIN32 DLL编写。一个是DLL部分,即要注入到系统的钩子,还有一个是界面程序部分。

附件中LibProcessProtector是DLL,ProcessProtector就是界面程序。

下载地址:

http://cid-856b7a1fbf560755.skydrive.live.com/self.aspx/My%20free%20softwares/ProcessProtecter.rar

版权声明:CAPI类的封装是由Jeffery richter在《windows via c/c++》中提供的。 

Copyright © 2024 Samson小天
Powered by .NET 8.0 on Kubernetes