mstsc服务 Python mstsc命令_mstsc服务 Python

1,摘要

本文作为产品技术穿刺任务的一个成功,探索通过浏览器调用本地程序完成远程WINDOWS桌面登录访问的功能。本文包含三部分内容:
(1) 介绍WINDOWS自带的mstsc和命令详情;
(2) 实践通过命令方式调用远程桌面系统;
(3) 编写JS脚本页面,通过IE浏览器调用远程桌面程序;
(4) 遗留问题:MAC电脑远程访问,CHROME浏览器远程访问的方法;

2. WINDOWS自带的mstsc和命令详情

Mstsc (Microsoft terminal services client) 是一款专用于Windows远程桌面连接的工具,小伙伴们可以使用这款windows远程桌面mstsc远程管理计算机。

2.1 语法

  • mstsc.exe {ConnectionFile|/v:server} [/console] [/f] [/w:width /h:height]
  • mstsc.exe /edit"ConnectionFile"
  • mstsc.exe /migrate

2.2 参数

  • ConnectionFile 指定用于连接的 .rdp 文件的名称
  • /v:server[;port] 指定要连接的远程计算机
  • /admin 将连接到会话以管理服务器
  • /f 在全屏幕模式下启动“远程桌面”连接
  • /w:width 指定远程桌面窗口的宽度
  • /h:height 指定远程桌面窗口的高度
  • /public 在公用模式下运行远程桌面
  • /span 是远程计算机的高度和宽度与本地虚拟桌面相匹配,如有必要扩展到多个显示器。若要扩展到多个显示器,所有显示必须具有相同的高度并垂直排列
  • /console 连接到指定 Windows 2000 Server 的控制台会话
  • /edit 打开指定的 .rdp 文件进行编辑
  • /migrate 将使用“客户端连接管理器”创建的旧版连接文件迁移到新的 .rdp 连接文件中

2.3 说明

您必须是要连接的服务器上的管理员才能创建远程控制台连接。  对于每个用户来说,.rdp 文件在“我的文档”中是作为隐藏文件存储的。  mstsc 与远程客户端之间是用Microsoft的远程桌面协议(Remote Desktop Protocol,简称RDP) 连接的,而windows xp的rdp有1个并发数的连接限制。

3. 命令方式访问WINDWOS远程桌面

3.1 需要输入用户名命名的方式

mstsc /v:101.91.194.13 /admin /f

弹出mstsc程序,输入用户名,密码即可访问远程桌面系统了。

mstsc服务 Python mstsc命令_用户名_02

3.2 不需要输入用户名命名的方式

编辑好配置文件,例如"a.rdp",密码被篡改为无效了的。然后把它存放到C盘根目录下。如下:

screen mode id:i:1 
desktopwidth:i:1280 
desktopheight:i:750 
session bpp:i:24 
winposstr:s:2,3,188,8,1062,721 
full address:s:MyServer 
compression:i:1 
keyboardhook:i:2 
audiomode:i:0 
redirectdrives:i:0 
redirectprinters:i:0 
redirectcomports:i:0 
redirectsmartcards:i:0 
displayconnectionbar:i:1 
autoreconnection 
enabled:i:1 
username:s:administrator
domain:s:MicrosoftAccount
alternate shell:s: 
shell working directory:s: 
password 51:b:01000000D08C9DDF0115D1218C7A00C04FC297EB01000200D06D956B23D5234E8F1E0A9436BA8C1504000000080000007000730077000000106600000001000020000000A43FFE5F00E742FE51542E8F55DB2361A01C993B343634148E69360344061DBE000000000E8000000002000020000000B24430A4F680B6EAE7845E44135DC5F3A011345F2B1B42036C9E0038A9A6F729200000000F1CB381FF5135A86FF3387D51093FAEEE27EFBBAA35A4DC9D921630BDCD9AF040000000CD8C103C9F0385686DEBF16803A55B5B777E6F05B6E177EA24A7EFCEFDAA22299C59A3ED64BF8B147DE79B2E6A16383F0ABC9D6AA95CA752EC24A35B031CFCBC
disable wallpaper:i:1 
disable full window drag:i:1 
disable menu anims:i:1 
disable themes:i:0 
disable cursor setting:i:0 
bitmapcachepersistenable:i:1

其中密码不是原始密码,而是经过加密算后的密码。该工具可从辉哥的知识星球下载。
辉哥知识星球:https://t.zsxq.com/EiyNbqB

执行命令:

mstsc C:/a.rdp /v:101.91.194.13 /admin /f

自动调用mstsc,确认后直接登录远程WINDOWS桌面系统了。

mstsc服务 Python mstsc命令_远程桌面_03

4. 编写JS脚本页面,通过IE浏览器调用远程桌面程序

编写脚本程序,如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
<script>
  function runcmd(value) { 
    let WSH=new ActiveXObject("WScript.Shell"); 
    WSH.run(value); 
    console.log('222'+ value)
    cmd = null;
    } 
  function run() {
      var command = "mstsc C:/a.rdp /v:101.91.194.13 /admin /f" //这里是执行的DOS命令
      runcmd(command);
  }
  run()
</script>
<body>
  
</body>
</html>

在IE浏览器下执行该程序,发现也能不需要输入用户名/密码就可以远程访问WINDOWS桌面系统了。

mstsc服务 Python mstsc命令_mstsc服务 Python_04

5. 遗留问题:MAC电脑远程访问,CHROME浏览器远程访问的方法

5.1 MAC电脑远程访问

WINDOWS访问的方式已经实现了。那么,MAC呢?发现了这篇文章《Mac使用RDC远程连接Windows并传输文件》,应该也有方法找到对应的命令吧,还有待测试。

5.2 CHROME浏览器远程访问的方法

上面的JS脚本程序在IE浏览器能访问,但是在CHROME浏览器下报错,不能访问。那么有没有什么方法做到浏览器通用呢?有待其他人提供解决方案。

6. 参考

(1)mstsc保存用户名和密码,实现自动登录远程桌面

(2)mstsc命令详解

(3)mstsc远程桌面打开命令

(4)RDP密码加密工具

(5)远程桌面,RDP文件密码加密、解密算法(C#)

(6)用Javascript调用cmd并执行命令
https://zhidao.baidu.com/question/545967631.html (7)Javascript中使用WScript.Shell对象执行.bat文件和cmd命令
(8)Mac使用RDC远程连接Windows并传输文件