VNC client web application
Go to file
Joel Martin c54a65ba09 README.md: try browser tests in table. 2010-07-02 12:25:13 -05:00
docs README/TODO: Windows browser testing results. 2010-07-02 12:02:57 -05:00
include Rebuild web-socket-js swf with gimite updates. 2010-07-02 10:50:52 -05:00
tests Support WebSockets 76 (hixie-76, hybi-00). 2010-06-24 17:04:57 -05:00
utils Remove sequence code in client and proxies. 2010-07-01 12:13:17 -05:00
.gitignore First pass at working C wsproxy. 2010-06-04 17:10:06 -05:00
LICENSE.GPL-3 Add missing full GPL-3 text. 2010-06-24 18:04:40 -05:00
LICENSE.LGPL-3 Change license to LGPL-3 and add some implementation notes. 2010-05-26 15:43:00 -05:00
LICENSE.txt Change license to LGPL-3 and add some implementation notes. 2010-05-26 15:43:00 -05:00
README.md README.md: try browser tests in table. 2010-07-02 12:25:13 -05:00
vnc.html Opera works! Fix message event drops/reorders. 2010-07-01 09:53:38 -05:00
vnc_auto.html Opera works! Fix message event drops/reorders. 2010-07-01 09:53:38 -05:00

README.md

noVNC: HTML5 VNC Client

Description

noVNC is a VNC client implemented using HTML5 technologies, specifically Canvas and WebSocket (supports 'wss://' encryption).

For browsers that do not have builtin WebSocket support, the project includes web-socket-js, a WebSocket emulator using Adobe Flash (http://github.com/gimite/web-socket-js).

In addition, as3crypto has been added to web-socket-js to implement WebSocket SSL/TLS encryption, i.e. the "wss://" URI scheme. (http://github.com/lyokato/as3crypto_patched).

Requirements

Until there is VNC server support for WebSocket connections, you need to use a WebSocket to TCP socket proxy. There is a python proxy included ('wsproxy'). One advantage of using the proxy is that it has builtin support for SSL/TLS encryption (i.e. "wss://").

There a few reasons why a proxy is required:

  1. WebSocket is not a pure socket protocol. There is an initial HTTP like handshake to allow easy hand-off by web servers and allow some origin policy exchange. Also, each WebSocket frame begins with 0 ('\x00') and ends with 255 ('\xff').

  2. Javascript itself does not have the ability to handle pure byte strings (Unicode encoding messes with it) even though you can read them with WebSocket. The python proxy encodes the data so that the Javascript client can base64 decode the data into an array.

  3. When using the web-socket-js as a fallback, WebSocket 'onmessage' events may arrive out of order. In order to compensate for this the client asks the proxy (using the initial query string) to add sequence numbers to each packet.

Usage

  • To encrypt the traffic using the WebSocket 'wss://' URI scheme you need to generate a certificate for the proxy to load. You can generate a self-signed certificate using openssl. The common name should be the hostname of the server where the proxy will be running:

    openssl req -new -x509 -days 365 -nodes -out self.pem -keyout self.pem

  • run a VNC server.

    vncserver :1

  • run the python proxy:

    `./utils/wsproxy.py -f source_port target_addr:target_port

    ./utils/wsproxy.py -f 8787 localhost:5901

  • run the mini python web server to serve the directory:

    ./utils/web.py PORT

    ./utils/web.py 8080

  • Point your web browser at http://localhost:8080/vnc.html (or whatever port you used above to run the web server).

  • Specify the host and port where the proxy is running and the password that the vnc server is using (if any). Hit the Connect button and enjoy!

Browser Support

Linux (Ubuntu 9.04)

OS Browser Status Notes
Ubuntu 9.04 Chrome 5.0.375.29 Works great Very fast. Native WebSockets.
Ubuntu 9.04 Firefox 3.5 Works well Large full-color images are somewhat slow due to web-socket-js overhead.
Ubuntu 9.04 Opera 10.60 Works Rendering performance is between firefox 3.5 and Chrome. However web-socket-js interaction causes overall performance to be lower than firefox 3.5 and causes occasional hangs.
Ubuntu 9.04 Arora 0.5 Works Broken putImageData so large full-color images are slow. Uses web-socket-js.
Ubuntu 9.04 Konqueror 4.2.2 Broken web-socket-js never loads
Windows XP Chrome 5.0.375.99 Works great Very fast. Native WebSockets.
Windows XP Firefox 3.0.19 Works well Some overhead from web-socket-js.
Windows XP Safari 5.0 Works Fast. Native WebSockets. However 'wss://' (SSL/TLS) does not work because client sends strange handshake.
Windows XP Internet Explorer 6, 7, 8 Non-starter No basic Canvas support. Javascript painfully slow.

Integration

The client is designed to be easily integrated with existing web structure and style.

At a minimum you must include the vnc.js and default_controls.js scripts and call their load() functions. For example:

<head>
    <script src='include/vnc.js'></script>
    <script src="include/default_controls.js"></script>
</head>
<body>
    <div id='vnc'>Loading</div>
</body>
<script>
    window.onload = function () {
        DefaultControls.load('vnc');
        RFB.load(); };
</script>

See vnc.html and vnc_auto.html for examples. The file include/plain.css has a list of stylable elements.

The vnc.js also includes other scripts within the include sub-directory. The VNC_uri_prefix variable can be use override the URL path to the directory that contains the include sub-directory.