S1r*_*lot 14 remote-desktop windows-10
启动远程 RDP 连接到计算机时,如何防止远程计算机锁定屏幕?
这个问题“在 Windows 10 中远程桌面会话后禁用锁定屏幕”是为了断开连接,所以它没有帮助。
这个问题“不锁定远程计算机的远程桌面连接”适用于 Windows 7 和 8,命令不适用于 Windows 10;此问题中引用的所有命令都会断开 rdp 会话。此外,没有为该问题选择答案,因为它没有提供该问题的有效解决方案。
具体来说,tscon %sessionname% /dest:console将断开会话。
您购买了允许您将 RDP 主机作为终端服务器运行的许可证。使用 RDP 时出现这种屏幕锁定的原因是 Windows 的消费者许可证一次只允许一个活动会话。让您继续使用 RDP 的唯一可靠方法是将系统许可为终端服务器,这很昂贵并且可能需要企业版或教育版许可证。
或者,还有多种其他选项可用于远程访问 Windows 系统。如果您只关心从本地网络的访问,VNC 可能是您最好的选择(除非您需要对会话进行加密)。如果您需要异地访问,您可以在网上找到许多选项,这些选项不仅不涉及 RDP,而且还提供了一个很好的可见指示,表明有人远程连接到会话(并且通常提供某种聊天功能)本地用户与远程用户通话)。
小智 7
我找到了代替重新启动的解决方案:
query session以Session ID获取RDP%UserProfile%\Desktop\close.bat,替换SessionId为步骤 1 的结果:
echo off
Tscon %SessionId% /Dest:console
Run Code Online (Sandbox Code Playgroud)
close.bat而不是从会话断开连接根据 Urumanathan Palanivel 的回答,可以使用以下 CloseRdp.cmd ;
@echo off
for /f "tokens=1,2,3 delims= " %%i in ('query session ^| findstr "Active"') do set SessionId=%%k
Tscon %SessionId% /Dest:console
Run Code Online (Sandbox Code Playgroud)
根据基于 Uramanathan 的答案的 subcoder 的答案,以及 Duncan 和 Jimadine 的评论的补充,我创建了一个在关闭/断开 RDP 连接时运行的计划任务。它需要对 findstr 命令进行轻微调整来搜索%USERNAME%而不是Active,因为在触发事件时,会话已经处于该Disc状态。
Microsoft-Windows-TerminalServices-LocalSessionManager/Operational该任务由事件日志获取注销事件 ( )触发EventID=24。然后,每当用户注销时,它就会运行一个简单的命令。该命令获取的query session输出如下所示:
SESSIONNAME USERNAME ID STATE TYPE DEVICE
services 0 Disc
>rdp-tcp#0 Matt 2 Active
console 5 Conn
rdp-tcp 65536 Listen
Run Code Online (Sandbox Code Playgroud)
它搜索%USERNAME%(在我的例子中为“Matt”)并获取该行的 ID 列。它将 ID 传递给tscon命令%k /Dest:console,该命令为登录用户解锁屏幕。该命令可能仅在远程登录的用户与本地登录的用户相同的情况下才有效,但我尚未测试。
这是要导入的任务计划程序 XML。Author 和 UserId 元素将被删除,并在您导入任务时自动填充您的用户。
<?xml version="1.0" encoding="UTF-16"?>
<Task version="1.2" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
<RegistrationInfo>
<Date>2022-02-10T11:17:45.9347484</Date>
<URI>\Unlock remote screen</URI>
</RegistrationInfo>
<Triggers>
<EventTrigger>
<Enabled>true</Enabled>
<Subscription><QueryList><Query Id="0" Path="Microsoft-Windows-TerminalServices-LocalSessionManager/Operational"><Select Path="Microsoft-Windows-TerminalServices-LocalSessionManager/Operational">*[System[Provider[@Name='Microsoft-Windows-TerminalServices-LocalSessionManager'] and (EventID=24)]]</Select><Suppress Path="Microsoft-Windows-TerminalServices-LocalSessionManager/Operational">*[UserData[EventXML[Address="LOCAL"]]]</Suppress></Query></QueryList></Subscription>
</EventTrigger>
</Triggers>
<Principals>
<Principal id="Author">
<LogonType>InteractiveToken</LogonType>
<RunLevel>HighestAvailable</RunLevel>
</Principal>
</Principals>
<Settings>
<MultipleInstancesPolicy>Parallel</MultipleInstancesPolicy>
<DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
<StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
<AllowHardTerminate>true</AllowHardTerminate>
<StartWhenAvailable>false</StartWhenAvailable>
<RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
<IdleSettings>
<StopOnIdleEnd>true</StopOnIdleEnd>
<RestartOnIdle>false</RestartOnIdle>
</IdleSettings>
<AllowStartOnDemand>true</AllowStartOnDemand>
<Enabled>true</Enabled>
<Hidden>false</Hidden>
<RunOnlyIfIdle>false</RunOnlyIfIdle>
<WakeToRun>false</WakeToRun>
<ExecutionTimeLimit>PT1H</ExecutionTimeLimit>
<Priority>7</Priority>
</Settings>
<Actions Context="Author">
<Exec>
<Command>C:\Windows\System32\cmd.exe</Command>
<Arguments>/C "for /F "tokens=1,2,3 delims= " %i in ('query session ^| findstr "%USERNAME%"') do tscon %k /Dest:console"</Arguments>
<WorkingDirectory>%USERPROFILE%</WorkingDirectory>
</Exec>
</Actions>
</Task>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
71792 次 |
| 最近记录: |