【C#】UI自動化中關閉遠程桌面連接,鼠標鍵盤失效的解決方案
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
問題原因分析:
因為通過mstsc啟動遠程桌面連接時,被連接的Windows會啟動一個會話(Session)。此時你對遠程桌面窗口里面的所有操作(鼠標,鍵盤)將會‘翻譯’成TCP包傳輸過去,被連接的Windows接收到這些包之后,‘還原’命令并且在當前的活動會話上面執行。而當你斷開連接時(點X關閉),會話變成斷開狀態,Windows會自動關閉會話(這里這樣說是不準確的,事實上會話還是在的,只是狀態變成斷開的),也就導致了所有基于GUI的操作‘失效’了。
當最小化遠程桌面時,Windows為了節約網絡帶寬傳輸,會暫時“關閉會話”,導致你的模擬操作程序失效。
最初級的兩個解決方案:
1. 到遠程電腦上,登錄,然后關顯示器,走人,記住不要遠程登錄它;
2. 遠程連接,永遠不要關,也不能最小化。
當然我也有更好的解決方案,我的解決方案可以實現遠程桌面的窗口最小化或是關閉而不影響模擬鍵盤鼠標的腳本。
方案一:
在遠程桌面(被連接到的電腦)中先執行 query session 來查看當前登錄到的 session,(遠程桌面的 sessionName 都以 rdp-tcp 開頭):
然后用管理員用戶打開命令行工具,并執行 "tscon rdp-tcp#0 /dest:console",其中 rdp-tcp#0 為該該命令會關閉遠程桌面的連接,然后把連接返回給遠程的那臺電腦(繞開登錄過程)。這里的 console 只是一個 session 的名字,而這個名字的意思并非是 C# 中 “控制臺” 的意思,而是指帶有輸入輸出設備的機器,一般直接登錄電腦的會話就是 console。
假設電腦A執行 mstsc 連接到電腦B(連接成功后,電腦B黑屏),此時在電腦B上執行上述命令后(替換對應的session名字),電腦A中的遠程連接窗口會被關閉,并提示遠程連接會話已經終止。電腦B(假設運行在另一臺物理機上)會恢復到已經登錄的狀態,如果需要重新讓電腦B恢復鎖屏狀態,可以在電腦B上執行如下命令:
rundll32.exe user32.dll,LockWorkStation
方案二:
假設用于跑 UI 自動化的機器是虛擬機A,現在再使用另一臺虛擬機B作為中轉。本機先連接到虛擬機B,然后再從虛擬機B連接到虛擬機A,最后斷開虛擬機B。
方案三(窗口最小化失效的解決方案):
修改注冊表項(注:從機器A通過遠程桌面連接機器B,則需要在機器A上修改注冊表)
32位機器:
HKEY_CURRENT_USERSoftwareMicrosoftTerminal Server ClientRemoteDesktop_SuppressWhenMinimized
或
HKEY_LOCAL_MACHINESoftwareMicrosoftTerminal Server ClientRemoteDesktop_SuppressWhenMinimized
設置數據類型DWord,值為2
64位機器路徑不同:
HKEY_CURRENT_USERSoftwareWow6432NodeMicrosoftTerminal Server ClientRemoteDesktop_SuppressWhenMinimized
或
HKEY_LOCAL_MACHINESoftwareWow6432NodeMicrosoftTerminal Server ClientRemoteDesktop_SuppressWhenMinimized
設置數據類型DWord,值為2
方案四(關機失效的解決方案):
遠程桌面mstsc遠程登錄虛擬機時,在虛擬機中新建文本文檔,寫入內容:
@%windir%\System32\tscon.exe 0 /dest:console
@%windir%\System32\tscon.exe 1 /dest:console
@%windir%\System32\tscon.exe 2 /dest:console
將文本文檔重新命名為‘Close_RDP’,并將后綴名改為‘.bat’,雙擊文件‘EnableCloseRDP.bat’關閉虛擬機,在虛擬機關閉后帶有SendKey的腳本可以正常運行。打開時可能會報錯,不用理會,不影響使用。
該文章在 2021/3/15 12:33:39 編輯過 |
關鍵字查詢
相關文章
正在查詢... |