websockify/README.md

165 lines
5.1 KiB
Markdown
Raw Normal View History

## noVNC: HTML5 VNC Client
### Description
2010-05-12 15:39:38 +01:00
noVNC is a VNC client implemented using HTML5 technologies,
specifically Canvas and WebSocket (supports 'wss://' encryption).
2010-04-19 02:53:54 +01:00
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
2010-04-19 02:53:54 +01:00
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://").
2010-04-19 02:53:54 +01:00
There a few reasons why a proxy is required:
2010-04-19 02:53:54 +01:00
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').
2010-04-07 03:37:35 +01:00
2. Javascript itself does not have the ability to handle pure byte
2010-04-19 02:53:54 +01:00
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.
2010-04-19 02:53:54 +01:00
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.
2010-04-19 02:53:54 +01:00
`vncserver :1`
* run the python proxy:
2010-06-17 23:50:15 +01:00
`./utils/wsproxy.py -f source_port target_addr:target_port
2010-06-17 23:50:15 +01:00
`./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).
2010-04-19 02:57:34 +01:00
* Specify the host and port where the proxy is running and the
2010-04-19 02:53:54 +01:00
password that the vnc server is using (if any). Hit the Connect
button and enjoy!
### Browser Support
2010-06-21 19:20:57 +01:00
2010-07-02 18:40:29 +01:00
In the following table Jaunty is Ubuntu 9.04 and WinXP is Windows XP.
#### Linux (Ubuntu 9.04)
2010-06-21 19:20:57 +01:00
2010-07-02 18:12:30 +01:00
<table>
<tr>
2010-07-02 18:40:29 +01:00
<th>OS</th> <th>Browser</th>
<th>Status</th>
<th>Notes</th>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>Jaunty</td> <td>Chrome 5.0.375.29</td>
<td>Excellent</td>
<td>Very fast. Native WebSockets.</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>Jaunty</td> <td> Firefox 3.5</td>
<td>Good</td>
<td>Large full-color images are somewhat slow due to
web-socket-js overhead.</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>Jaunty</td> <td> Opera 10.60</td>
<td>Fair</td>
<td>web-socket-js interaction problems: slower than firefox,
occasional hangs.</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>Jaunty</td> <td> Arora 0.5</td>
<td>Good</td>
<td>Broken putImageData so large full-color images
are slow. Uses web-socket-js.</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>Jaunty</td> <td> Konqueror 4.2.2</td>
<td><strong>Broken</strong></td>
<td>web-socket-js never loads</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td></td>
<td></td>
<td></td>
<td></td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>WinXP</td> <td> Chrome 5.0.375.99</td>
<td>Excellent</td>
<td>Very fast. Native WebSockets.</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>WinXP</td> <td> Firefox 3.0.19</td>
<td>Good</td>
<td>Some overhead from web-socket-js.</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>WinXP</td> <td> Safari 5.0</td>
<td>Fair</td>
<td>Fast. Native WebSockets. Broken 'wss://'
(SSL) - weird client header</td>
2010-07-02 18:25:13 +01:00
</tr> <tr>
2010-07-02 18:40:29 +01:00
<td>WinXP</td> <td> IE 6, 7, 8</td>
<td><strong>Non-starter</strong></td>
<td>No basic Canvas support. Javascript painfully slow.</td>
2010-07-02 18:12:30 +01:00
</tr>
</table>
### Integration
The client is designed to be easily integrated with existing web
structure and style.
2010-06-03 14:39:42 +01:00
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>
2010-06-03 14:39:42 +01:00
See `vnc.html` and `vnc_auto.html` for examples. The file
`include/plain.css` has a list of stylable elements.
2010-06-02 23:28:28 +01:00
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.