网络安全编程
|
编译连接上面的程序,然后打开一个空的记事本程序,运行这个编译好的程序,会发现记事本程序的进程被结束掉了,这里的程序弹出一个简单的对话框,提示“结束进程成功”。 2. 结束进程所需API函数说明 在上面的程序代码中,结束进程的API函数一共用到了4个,分别是FindWindow()、GetWindowThreadProcessId()、OpenProcess()和TerminateProcess()。 GetWindowThreadProcessId()函数的定义如下:数说明如下。 hWnd:窗口句柄,代码中的窗口句柄是由 FindWindow()函数获取的。 lpdwProcessId:该参数是一个指向 DWORD 类型的指针,用户返回窗口句柄所对应的进程 ID。 GetWindowThreadProcessId()函数在得到进程 ID 后,将进程 ID 传递给 OpenProcess() 函数来得到进程的句柄。OpenProcess()函数的定义如下:数说明如下。 dwDesiredAccess:打开进程欲获得的访问权限,该参数为了方便,可以始终为 PROCESS_ALL_ACCESS。 bInheritHandle:指定获取的句柄是否可以继承,一般选择不继承,传递值为 FALSE。 dwProcess:指定欲打开的进程 ID 号,该进程 ID 号是由 GetWindowThreadProcessId()获得的。 该函数的返回值为进程的句柄,通过这个句柄就可以调用 TerminateProcess()函数来进行结束。TerminateProcess()函数的定义如下:数说明如下。 hProcess:欲结束进程的进程句柄,该句柄已经由 OpenProcess()函数得到。 uExitCode:进程的退出码,通常为 0 值。 通过一些列的API函数,完成了一个结束进程的程序。结束程序时的第一步是得到窗口的句柄,如果这个进程没有窗口,是不是就没有办法通过程序去结束进程了?其实还是有办法的。
从上面的3个API函数中可以看到,通过进程的窗口可以得到进程的ID,通过进程的ID可以得到进程的句柄。他们内部本身都是有关联的,因此,在需要使用相关资源时,如果不能直接得到的时候,不妨通过这样的方式逐步去得到。 (编辑:张家口站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |

