| ||
|
| Linux首页 | Linux论坛 | 论坛精华 | 开源新闻 | 技术文章 | 专题专栏 | 新手指南 | 迁移方案 | 产品方案 | 开源项目 | 开源图书 | 软件下载 | 人才招聘 | Linux博客 |
| 您的位置:
Linux时代 > 技术文档 > 网络通讯 >
使用SSL 保护VNC应用程序
SSL 为使用 VNC 和标准 Web 浏览器对远程桌面进行方便、安全的访问提供了一种新颖的机制。 您希望使用比专有解决方案更方便并且具有比 ssh 更具安全性的方式来访问远程桌面吗?本文将介绍一种很好的方法,这是我们之前从未介绍过的一种技术。 这种想法是使用 SSL 为嵌入在 Web 页面中的一个简单 VNC 查看器提供安全性。这意味着实际上任何可以处理 Java 的 Web 浏览器都可以查看远程桌面,并与之进行交互;对于典型的情况来说这是一个功能十分强大的解决方案,包括电话协作、技术支持和供应。 计算机在这里,屏幕在那里 计算机在某个位置执行一个操作,在其他地方的人希望看到结果。符合这种描述的情况非常多,实现这种功能的方法也几乎同样多。有一种方法是将常规的单个桌面作为一个使用 HTTPS 协议进行保护的 Web URL 地址来发布,在与那些非软件专家的人一起工作时,这种方法特别方便。通过一个连接到远程桌面的超链接或仅在浏览器的地址栏输入 URL 即可进行远程访问,这对于 “平民” 用户来说非常方便。 只需要花几分钟的功夫,您就可以建立自己的远程桌面。这种方法的一个重要功能特性是它进行认证的方法:它并不基于登录级别的帐号,后者常见于基于 ssh、IPv6、OpenVPN 和大部分专有产品的远程访问机制,我们将展示如何为 SSL 设置帐号/密码对。这是一种非常 “轻量级” 的方法,可以与桌面主机上的其他用途隔离开来。同时,这种方法在 Web 上应用广泛,并且是一种关键的技术,大部分开发人员来此非常熟悉。 尽管只需要几个步骤就可以实现通过 SSL 来访问 VNC,但是这个配置的核心存在一个复杂的问题:Jva VNC 客户机不会连接到那些自己对证书进行签名的 SSL 站点上。更确切地说,流行浏览器所使用的 JVM 通常都需要经过 “受信任的第三方” 认证权威(CA)签名的证书。 这篇文章对读者进行了有效地分类。可能由于管理或开发安全 Web 站点的需要您已经开始使用 SSL,那就可以立即在 VNC-through-SSL 项目中使用相同的 Web 服务器和经过签名的证书。如果您 尚不具备 使用 SSL 的背景知识,那么这种技术则不是一个很好的入门。对您来说,更传统的 ssh 隧道或 Hamachi 以及商业解决方案可能是通向远程桌面的更简单起点。更多信息请参看侧栏的 证书和 SSL。 方法 第一个步骤是设置 VNC 服务器以及相应的隧道。对于这个步骤来说,您必须具有一个允许创建有效密钥文件的证书,包括一个私钥和一个公钥。将密钥放置在
尽管大部分 Linux 主机都进行了设置以允许任何用户都可以启动 现在,服务器应该为地址
出现的错误 —— 密钥文件无效,没有足够的权限,或者端口已经被使用 —— 出现在同样的日志文件中。例如,如果缺少密钥,在日志中的形式如下:
由于服务器可以同时处理未加密端口和已加密端口,下面让我们转到 VNC Web 客户机上来。要启用这种功能,需要从 x11vnc 项目中下载启用 SSL 的 Java VNC 查看器。在下载源 tarball 文件之后,就可以使用位于 x11vnc-X.Y.Z/classes/ssl/VncViewer.jar 和 x11vnc-X.Y.Z/classes/ssl/SignedVncViewer.jar 中的 Java 代码了。设置一个目录来存放 VNC 的内容,将 VncViewer.jar 拷贝到这个目录中,并创建一个 HTML 源文件。这个样例 HTML 文件允许通过 SSL 连接到
HTTP 和 HTTPS 都可以为该 applet 服务。假设 HTML 和 Jar 文件在端口 80 上使用了 HTTP 服务,URI 为
更多使用技巧 使用标准组件和协议的一个优点是它们可以非常简单地进行替换。例如,我们的开发大部分都采用了 Xvnc 服务器,还有一些方法可以取代上面方法中的 TightVNC。注意这些替代方法使用的命令行参数可能会稍有不同;不过,在所有情况中,原理都是相同的。几乎所有的 Linux 发行版都提供了根据发行版标准进行封装的 VNC 服务器,一些开源 VNC 项目甚至很容易从源代码进行安装。任何 VNC 服务器安装中最困难的部分是需要特定的默认字体。不过,即使在这种情况下,至少提供了明确的补救措施。 在浏览器中使用启用 SSL 的 VNC 查看器至少存在一点风险。它在所有主要浏览器中都可以使用,包括 Mozilla Firefox、Internet Explorer 和 Opera,不过所有浏览器都需要使用 Java runtime 1.4 或更高版本。当用户使用旧版本的 Microsoft Windows 操作系统时就会出现问题,旧系统仍然依赖于 Microsoft JVM 1.1。在这种情况下,VNC 查看器无法在 Internet Explorer 上运行,并发送报告表示找不到 默认情况下,大部分 VNC 服务器都 不 共享桌面;即任何连接都会关闭之前的连接。要进行协作、技术支持以及类似的应用,使用一个命令行参数 重点是什么? 尽管您可能已经使用了 VNC、Web 服务、Java、SSL、浏览器等等,不过您可能从来没有将它们结合在一起使用。现在您究竟获得了什么呢?
实际上,您现在获得的东西非常多。首先,这是一个非常类似于 GUI 的 不过,您还获得了更多内容。VNC 对于电话会议来说非常方便。例如,我们使用它来为非技术用户建立一个复杂图形应用程序的展示。原则上来说,远程 X 服务器也可以执行相同的功能,但是 VNC 提供了很多优点:
另外使用该技术的例子的一个关键点是最繁重的加密计算负载是由 “本地” 代码非 Java 运行时来执行的。尽管假设网络延时是决定性能的第一个因素是非常安全的,但是加密和解密的代价太高,使得无法使用其他替代技术(除非使用具有极高性能的计算机)。通过 SSL 使用 VNC 的一个令人愉悦的优点是,在旧硬件甚至非常简单的硬件上使用标准软件就可以快速产生可以接受的响应能力。 您可能还有一些不同的需求和资源。您需要自己确定 VNC 与 Citrix、Windows Terminal services、 WebEx、Hamachi 以及其他 “远程” 解决方案所提供的商业软件相比到底如何。不过,我们已经看到通过 SSL 使用 VNC 已经解决了相当多的问题。 在后续文章中,我们将展示如何将 VNC 与其他虚拟化技术组合在一起实现功能强大的资源共享技术。不过在结束本文之前,有一点重要的问题需要提醒读者:VNC 存在非常严重的安全问题。由于 VNC 只使用一个会话密码进行保护,如果对标准 VNC 服务进行几个小时或几天的蛮力攻击,很可能就会破解。对 VNC 感兴趣的 “坏家伙们” 的数量正在迅速增加;请 确保 您对 VNC 使用了一个非常强壮的密码,至少有 8 个字母,最好是数字、字母和其他符号的组合。SSL 提供了很多保护机制,如果每次会话时间要持续几个小时,就应该考虑使用这些保护机制。在后续文章中我们将更详细地介绍安全性问题。 上面的方法利用了几个功能强大的开源示例,但是它本身几乎没有实现独创的编程。居然没有人编写文档来论述将这些组件组合起来,而这种组合非常的方便,这实在令人惊讶。有关 VNC、SSL 和其他内容的更详细介绍请参看 参考资料 一节的内容。 结束语 在下一篇文章中,我们将更详细介绍两个通过 SSL 使用 VNC 可以大展宏图的特定工作场所,以及如何在自己的环境中采用这种技术,包括如何与防火墙和代理协作使用。我们还将介绍使用 “本地” VNC 查看器与本文提到的承载浏览器的客户机协同工作何时能够成为一个优点。 这里要特别感谢 Matt Kennel,他和我们一样担心安全性问题,并对如何实际应用通过 SSL 使用 VNC 的技术与我们进行了讨论。 原文链接:http://www.ibm.com/developerworks/cn/linux/l-sslvnc.html 本文被浏览次
| ||||||||||||||||||
| 关于我们 | 联系方式 | 广告合作 | 诚聘英才 | 网站地图 | 免费注册 |
Copyright © 2001-2006 ChinaUnix.net All Rights Reserved 感谢所有关心和支持过ChinaUnix的朋友们 |