使用统一资源标识符 (Uniform Resource Identifier, URI) 创建网页或电子邮件链接,最终用户可以单击这些链接启动 Horizon Client、连接到服务器,或者打开远程桌面或已发布的应用程序。
通过构建提供以下部分或所有信息的 URI 来创建链接,这样最终用户就无需再提供它。
- 服务器地址
- 服务器的端口号
- Active Directory 用户名
- 域名
- 远程桌面或已发布的应用程序的显示名称
- 窗口大小
- 操作包括重置、注销和启动会话
- 显示协议
- 用于重定向 USB 设备的选项
要构建 URI,可使用包含 Horizon Client 特定路径和查询部分的 vmware-view URI 方案。
要使用 URI 启动 Horizon Client,必须已在客户端计算机上安装 Horizon Client。
用于创建 vmware-view URI 的语法
URI 语法包括 vmware-view URI 方案、用于指定远程桌面或已发布应用程序的路径部分以及用于指定远程桌面或已发布应用程序操作或配置选项的查询(可选)。
URI 规范
使用以下语法来创建用于启动 Horizon Client 的 URI。
vmware-view://[authority-part][/path-part][?query-part]
只有 URI 方案 vmware-view 是必需的元素。由于对于某些客户端操作系统的某些版本,方案名称区分大小写,因此请键入 vmware-view。
有关 ASCII 字符的编码信息,请参考 http://www.utf8-chartable.de/ 上的 URL 编码参考。
- authority-part
-
服务器地址以及(可选)用户名和/或非默认端口号。服务器名称中不能使用下划线 (_)。服务器名称必须遵循 DNS 语法。
要指定用户名,请使用下面的语法。
user1@server-address
您不能指定包含域的 UPN 地址。要指定域,可以使用 URI 中的 domainName 查询部分。
要指定端口号,请使用下面的语法。
server-address:port-number
- path-part
- 远程桌面或已发布应用程序的显示名称。该显示名称是在 Horizon Console 中创建桌面池或应用程序池时指定的。如果显示名称中包含空格,请使用 %20 编码机制来表示空格。
- query-part
-
要使用的配置选项,或者要执行的远程桌面或已发布应用程序操作。查询不区分大小写。要使用多个查询,请使用 & 符号分隔查询。如果查询之间有冲突,
Horizon Client 使用列表中的最后一个查询。使用以下语法。
query1=value1[&query2=value2...]
支持的查询
此类型的 Horizon Client 支持以下查询。如果要为多种类型的客户端(例如,桌面客户端和移动客户端)创建 URI,请参阅针对每种客户端系统类型的安装和设置指南,了解受支持的查询列表。
- action
-
表 1. 可与 action 查询一起使用的值 值 说明 browse 显示指定服务器上托管的可用远程桌面和已发布应用程序的列表。使用此项操作时无需指定远程桌面或已发布应用程序。 如果使用 browse 操作并指定一个远程桌面或已发布应用程序,则该远程桌面或已发布应用程序会在可用项目列表中突出显示。
start-session 打开指定的远程桌面或已发布的应用程序。如果未提供任何操作查询以及远程桌面名称或已发布应用程序名称,则 start-session 为默认操作。 reset 关闭并重新启动指定的远程桌面或已发布的应用程序。未保存的数据都会丢失。重置远程桌面与按下物理 PC 上的重置按钮相同。
restart 关闭并重新启动指定的远程桌面。重新启动远程桌面与 Windows 操作系统重新启动命令相同。在重新启动之前,操作系统通常会提示用户保存任何未保存的数据。 logoff 将用户从远程桌面中的客户机操作系统中注销。如果指定已发布的应用程序,则此操作被忽略,或者最终用户看到一条警告消息“URI 操作无效”。 - args
-
指定要在已发布的应用程序启动时添加的命令行参数。使用语法
args=
value,其中
value 是字符串。对于以下字符,使用百分号编码:
- 对于冒号 (:),使用 %3A
- 对于反斜杠 (\),使用 %5C
- 对于空格 ( ),使用 %20
- 对于双引号 ("),使用 %22
例如,要为 Notepad++ 应用程序指定 "My new file.txt" 文件名,请使用 %22My%20new%20file.txt%22。
- appProtocol
- 对于已发布的应用程序,有效值为 PCOIP 和 BLAST。例如,要指定 PCoIP,请使用 appProtocol=PCOIP 语法。
- connectUSBOnInsert
- 插入 USB 设备时,将其连接到前台远程桌面或已发布的应用程序。如果您为远程桌面指定了 unattended 查询,则此查询将以隐式方式设置。要使用此查询,您必须将 action 查询设置为 start-session,或者不使用 action 查询。有效值为 true 和 false。举例说明该语法: connectUSBOnInsert=true。
- connectUSBOnStartup
- 将当前连接到客户端系统的所有 USB 设备重定向至远程桌面或已发布的应用程序。如果您为远程桌面指定了 unattended 查询,则此查询将以隐式方式设置。要使用此查询,您必须将 action 查询设置为 start-session,或者不使用 action 查询。有效值为 true 和 false。举例说明该语法: connectUSBOnStartup=true。
- desktopLayout
-
设置显示远程桌面的窗口大小。要使用此查询,您必须将
action 查询设置为
start-session,或者不使用
action 查询。
表 2. desktopLayout 查询的有效值 值 说明 fullscreen 在连接的所有外部显示器中全屏显示。该值是默认值。 windowLarge 大窗口。 windowSmall 小窗口。 WxH 自定义分辨率,您可以以像素为单位指定宽乘高。举例说明该语法:desktopLayout=1280x800。 - desktopProtocol
- 对于远程桌面,有效值为 PCOIP 和 BLAST。例如,要指定 PCoIP,请使用 desktopProtocol=PCOIP 语法。
- domainName
- 指定与连接到远程桌面或已发布应用程序的用户相关联的 NETBIOS 域名。例如,您可以使用 mycompany,而非 mycompany.com。
- filePath
-
指定本地系统上您要使用已发布的应用程序打开的文件的路径。您可以指定完整路径或相对路径,例如,
~/username/test%20file.txt。对于以下字符,使用百分号编码:
- 对于冒号 (:),使用 %3A
- 对于反斜杠 (\),使用 %5C
- 对于空格 ( ),使用 %20
例如,要表示文件路径 /Users/username/test file.txt,请使用 /User/username/test%20file.txt。
vmware-view URI 示例
您可以使用 vmware-view URI 方案来创建超文本链接或按钮,并将这些链接包含在电子邮件或网页中。例如,最终用户可以单击 URI 链接,以使用您指定的启动选项启动远程桌面。
每个 URI 示例后都将包含最终用户在单击 URI 链接后所见到的内容描述。
-
vmware-view://view.mycompany.com/Primary%20Desktop?action=start-session
Horizon Client 启动并连接到 view.mycompany.com 服务器。出现登录对话框,提示用户输入用户名、域名和密码。成功登录后,客户端连接到显示名称为 Primary Desktop 的远程桌面,并且用户登录到客户机操作系统。
注: 在此示例中,会使用默认的显示协议和窗口大小。默认显示协议为 PCoIP,默认窗口大小为全屏。 -
vmware-view://view.mycompany.com/cn%3Dwin7-32%2Cou%3Dapplications%2Cdc%3Dvdi%2Cdc%3Dvmware%2Cdc%3Dint
Horizon Client 启动并连接到 view.mycompany.com 服务器。出现登录对话框,提示用户输入用户名、域名和密码。成功登录后,客户端连接到桌面 ID 为 CN=win7-32,OU=Applications,DC=vdi,DC=vmware,DC=int(编码值 cn%3Dwin7-32%2Cou%3Dapplications%2Cdc%3Dvdi%2Cdc%3Dvmware%2Cdc%3Dint)的远程桌面。
-
vmware-view://view.mycompany.com:7555/Primary%20Desktop
该 URI 与前面的示例效果相同,不同的是该 URI 对连接服务器实例使用 7555 非默认端口。(默认端口为 443。)由于已提供远程桌面标识符,因此即使 URI 中不包含 start-session 操作,远程桌面也能打开。
-
vmware-view://[email protected]/Finance%20Desktop?desktopProtocol=PCOIP
Horizon Client 启动并连接到 view.mycompany.com 服务器。在登录对话框中的用户名文本框中填入 fred。用户必须提供域名和密码。成功登录后,客户端连接到显示名称为 Finance Desktop 的远程桌面,并且用户登录到客户机操作系统。用 PCoIP 显示协议进行连接。
-
vmware-view://view.mycompany.com/Calculator?action=start-session&appProtocol=BLAST
Horizon Client 启动并连接到 view.mycompany.com 服务器。在登录对话框中,用户必须提供用户名、域名和密码。成功登录后,客户端连接到显示名称为 Calculator 的已发布应用程序。连接使用 VMware Blast 显示协议。
-
vmware-view://[email protected]/Finance%20Desktop?domainName=mycompany
Horizon Client 启动并连接到 view.mycompany.com 服务器。在登录对话框中的用户名文本框中填入 fred,域文本框中填入 mycompany。用户只需提供一个密码。成功登录后,客户端连接到显示名称为 Finance Desktop 的远程桌面,并且用户登录到客户机操作系统。
-
vmware-view://view.mycompany.com/
Horizon Client 启动,用户将看到连接 view.mycompany.com 服务器的登录提示。
-
vmware-view://view.mycompany.com/Primary%20Desktop?action=reset
Horizon Client 启动并连接到 view.mycompany.com 服务器。出现登录对话框,提示用户输入用户名、域名和密码。成功登录后,Horizon Client 会重置指定的桌面。
注: 只有在 Horizon 管理员为远程桌面启用了重置功能时,才能执行该操作。 -
vmware-view://view.mycompany.com/Primary%20Desktop?action=restart
Horizon Client 启动并连接到 view.mycompany.com 服务器。出现登录对话框,提示用户输入用户名、域名和密码。成功登录后,Horizon Client 会重新启动指定的桌面。
注: 只有在 Horizon 管理员为远程桌面启用了重新启动功能时,才能执行该操作。 -
vmware-view://
Horizon Client 启动,并且用户进入用于输入服务器地址的页面。
-
vmware-view://10.10.10.10/My%20Notepad++?args=%22My%20new%20file.txt%22
在服务器 10.10.10.10 上启动 My Notepad++,然后在已发布应用程序的启动命令中传递 My new file.txt 参数。文件名用双引号引起来,因为它包含空格。
-
vmware-view://10.10.10.10/Notepad++%2012?args=a.txt%20b.txt
在服务器 10.10.10.10 上启动 Notepad++ 12,然后在已发布应用程序的启动命令中传递 a.text b.txt 参数。由于该参数未用引号引起来,因此,文件名用空格隔开,并在 Notepad++ 中单独打开这两个文件。
注: 已发布的应用程序使用命令行参数的方式可能不相同。例如,如果将 a.txt b.txt 参数传递给 WordPad,WordPad 仅打开一个文件 ( a.txt)。
HTML 代码示例
您可以使用 URI 来创建超文本链接和按钮,以将其包含在电子邮件或网页中。以下示例介绍了如何使用第一个 URI 示例中的 URI 对标记为 Test Link 的超文本链接和标记为 TestButton 的按钮进行编码。
<html> <body> <a href="vmware-view://view.mycompany.com/Primary%20Desktop?action=start-session">Test Link</a><br> <form><input type="button" value="TestButton" onClick="window.location.href= 'vmware-view://view.mycompany.com/Primary%20Desktop?action=start-session'"></form> <br> </body> </html>