CMD和powershell都有打开进程的指令,人工执行都可以正常打开窗体程序。但是希望启动远端Windows上的窗体程序,却只能在后台运行,看不到窗体。原因是:windows的窗体会话隔离(session 隔离),具体细节可以自己搜索。
尝试过并失败的方式有:
- ansible运行远端windows的本地脚本,本地脚本打开窗体程序,会有session隔离;
- 在远端window创建任务计划,由任务计划打开窗体,手动执行任务计划可以打开窗体,但到了计划自动执行,还是出现session隔离。远程调用脚本执行任务计划,同样会有session隔离;
目前找到可以解决session隔离的远程调用方法只有:psexec
该工具在微软官网可以下载,下载地址和详细使用方法请自行百度。
psexec远程调用窗体程序,通过 -i 参数指定session的ID,即可在相应sessionid的会话打开。整体逻辑如下:
- 找到远程windows正在运行会话的sessionID;
- 调用psexec启动远程窗体程序,并通过-i参数指定sessionid;
1.找到当前运行的sessionid
为了找sessionid,我也尝试了很多方法,网上资料似乎非常少。最后我用的方法有点曲折,至少还是可以获取到吧。
整体逻辑如下:
使用tasklist查看远端windows运行的进程清单,并找到登录账号对应的进程清单,进程清单有sessionid。
Powershell代码如下:
#tasklist脚本详情请自行百度和翻译下述代码
$result = tasklist /s 192.168.1.12 /u administrator /p adminpwd /fi "session ne 0" /fi "username eq admin*" /NH
#用tasklist返回结果的第1行,因为第0行是空白
#用正则表达式匹配第1行中的sessionid,这里假定sessionid是个位整数,我试了几台虚拟机都是个位整数;
$result[1] -match "\s\d\s"
#将正则表达式匹配结果强制转换为int,便于下一步传参
$sessionid = [int]$Matches[0]
2.调用psexec启动远程窗体程序
psexec的使用方法在网上很常见,自行百度即可。重点在于-i参数要传入上面获取的$sessionid。具体Powershell代码如下:
& "D:\PSTools\PsExec64.exe" \\192.168.1.12 -u administrator -p adminpwd -d -i $sessionid "c:\test\myAPP.exe"
执行完这段代码,远程windows就打开了窗体程序myAPP.exe。执行完之后,我远程桌面进去总会卡一会,暂时不明白原理,稍微等会就好了。
本文介绍了如何解决远程Windows系统因会话隔离导致无法打开窗体程序的问题。通过使用PSTools中的psexec工具,结合PowerShell脚本获取远程系统的session ID,然后指定-i参数启动窗体程序,成功绕过session隔离。详细步骤包括使用tasklist获取session ID以及psexec的执行命令。
1392

被折叠的 条评论
为什么被折叠?



