这段时间在做一个指纹相关的项目,其中有一个功能就是要替换msgina.dll,来实现Windows的指纹登陆。因为指纹设备有时候会死掉,而且设备死掉的时候很麻烦,常常会导致进程崩溃,msgina.dll是由winlogon来调用的,如果设备死掉了,可能导致winlogon进程崩溃,用户将无法登陆系统。为了确保设备死掉不会影响用户正常登陆windows,我们不得不把指纹设备相关的所有代码都移植到另一个进程中,由一个独立的进程来提供指纹扫描和比对服务。同时这个进程还要给其它的应用提供指纹服务。这样,就涉及到不同的桌面间进程的通信的问题。而且这个问题还相当的头痛。 首先来介绍下windows下桌面的概念:在Windows NT/Windows 2000/Windows XP中, WinSta0 是表示物理屏幕、鼠标和键盘的Windows系统对象的名字。Winlogon在WinSta0 Windows系统中创建了SAS窗口(窗口标题是"SAS Window")和如下三个桌面。 Winlogon 桌面 应用程序桌面 (Default,用户桌面) 屏幕保护桌面 winlogon桌面是一个特殊的桌面,windows对这个桌面进行了一些特殊的处理,使得winlogon桌面与用户桌面之间的进程通信有些麻烦。 一开始我们尝试直接用postmessage和sendmessage,但是发现在winlogon桌面中调用Findwindow查找窗口会失败,这说明窗口在不同的桌面间是不可见的。于是我把接收方的窗口句柄写到一个注册表项里,在要发送消息的时候,从注册表中取出窗口句柄,结果发现这样发生消息,可以成功。但是用同样的方法,由应用程序给winlogon发生消息,结果发生失败,即使发生WM_COPYDATA也不行。事实证明: 从winlogon桌面往
Windows安全桌面与用户桌面间的通信
最新推荐文章于 2023-02-19 09:57:05 发布