windows – 为什么模拟会话中定义的DOS设备不会出现在资源管理器
我有一个在本地系统帐户下运行的
Windows服务,它使用DefineDosDevice函数创建DOS设备.该服务在W2K8远程桌面服务器上运行.如果使用服务的凭据创建设备,则它们将在GLOBAL设备命名空间中创建,因此对所有用户可见.我需要只对特定交互会话可见的设备.
我通过冒充我希望驱动器出现在其会话中的用户来实现此目的.如果会话ID可用,这是相当简单的.这是我编写的一个简单的测试应用程序来说明问题: int _tmain(int argc,_TCHAR* argv[]) { BOOL result = TRUE; if(argc > 3 && !wcscmp(argv[2],L"/i")) { HANDLE hToken = 0; DWORD dwSessionId = _wtoi(argv[3]); result = WTSQueryUserToken(dwSessionId,&hToken); if(result) result = ImpersonateLoggedOnUser(hToken); } if(result) { LPTSTR drive = argv[1]; DefineDosDevice(DDD_REMOVE_DEFINITION,drive,NULL); result = DefineDosDevice(0,L"C:test"); } if(!result) { printf("Error: %dn",GetLastError()); } return 0; } 为了测试这段代码,我创建了一个在LocalSystem帐户下启动命令shell的服务:
此服务无法启动,但在失败之前,它会生成在LocalSystem帐户下运行的命令shell. 从LocalSystem cmd.exe,我运行:
调用ImpersonateLoggedOnUser(),然后调用DefineDosDevice() 从用户会话中运行的cmd.exe,我运行:
它调用DefineDosDevice而不调用ImpersonateLoggedOnUser(). 这有效.从cmd.exe我可以访问两个驱动器X:和Y:.我可以从开始菜单启动notepad.exe,并查看X:和Y:驱动器.此外,如果我与不同的用户创建一个新的终端服务会话,我看不到X:或Y:. 但是,Explorer仅在“所有计算机”下显示Y:驱动器. Y:是通过在目标会话中运行的cmd.exe运行我的测试应用程序而创建的驱动器,即未进行模拟.如果我从任务管理器重新启动explorer.exe,则会显示X:和Y:驱动器. 我还使用了SysInternals的WinObj.exe来检查定义的Win NT设备.我看到的是: - Sessions - 0 - DosDevices 00000000-000057607 (57607是与我冒充的会话关联的登录会话的ID) “00000000-000057607”的内容是: Global SymbolicLink Global?? X: SymbolicLink ??C:test Y: SymbolicLink ??C:test 根据WinObj,两个dos设备是相同的.它们属于同一会话和登录会话.它们是同一NT对象的符号链接. 怎么可能是其中一个出现在资源管理器中而另一个不出现.
@arx和@HarryJohnston都在赚钱.如果我从与探索器相同的会话中的线程广播WM_DEVICECHANGE消息,则新驱动器将显示在“我的电脑”中.这是代码:
DWORD recipients = BSM_ALLDESKTOPS | BSM_APPLICATIONS; DEV_BROADCAST_VOLUME msg; ZeroMemory(&msg,sizeof(msg)); msg.dbcv_size = sizeof(msg); msg.dbcv_devicetype = DBT_DEVTYP_VOLUME; msg.dbcv_unitmask = 1 << ('X' - 'A'); long success = BroadcastSystemMessage(0,&recipients,WM_DEVICECHANGE,DBT_DEVICEARRIVAL,(LPARAM)&msg); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Windows安全(在Windows 7中)一直在询问我的凭据,并且不会“
- Windows – 运行node.js的Azure辅助角色是否会在节点进程终
- 在Windows 8上无法发送带有php邮件功能的邮件
- 有没有办法让tortisesvn使用Windows 7 kerberos票证来对抗a
- Windows C线程参数传递
- Windows – 如何成功更改执行策略并启用Powershell脚本的执
- iis – 方括号[]语法在WiX中意味着什么
- windows-phone-8 – wp8 LonglistSelector AnimateTo
- wpf – 动画边距/厚度
- winapi – 在Win32中注册FS
- 测试模式 windows2008 内部版本7601
- windows – 如何获取包含我的应用程序创建的所有
- Windows – 允许DHCP客户端在域服务器关闭时使用
- 什么时候支持Windows 64?
- windows-phone-7 – 使用RestSharp对Trello API进
- windows-server-2008 – Cygwin SSHd Autoblock登
- 修改win7 iis上传文件大小限制200KB
- active-directory – 有没有Sysinternals ADInsi
- 服务器安装windows2016选择磁盘时报错不能将系统
- Microsoft DirectX DirectShow指针验证远程代码执