<meta charset="UTF-8"> <html> <body> <img src="libwebsockets.org-logo.png"><br> <b>Minimal ws server threads example</b>.<br> Strings generated by server threads are sent to all browsers open on this page.<br> The textarea show the last 50 lines received. <br> <br> <textarea id=r readonly cols=40 rows=50></textarea><br> </body> <script> var head = 0, tail = 0, ring = new Array(); function get_appropriate_ws_url(extra_url) { var pcol; var u = document.URL; /* * We open the websocket encrypted if this page came on an * https:// url itself, otherwise unencrypted */ if (u.substring(0, 5) == "https") { pcol = "wss://"; u = u.substr(8); } else { pcol = "ws://"; if (u.substring(0, 4) == "http") u = u.substr(7); } u = u.split('/'); /* + "/xxx" bit is for IE10 workaround */ return pcol + u[0] + "/" + extra_url; } function new_ws(urlpath, protocol) { if (typeof MozWebSocket != "undefined") return new MozWebSocket(urlpath, protocol); return new WebSocket(urlpath, protocol); } ws = new_ws(get_appropriate_ws_url(""), "lws-minimal"); try { ws.onopen = function() { document.getElementById("m").disabled = 0; document.getElementById("b").disabled = 0; } ws.onmessage =function got_packet(msg) { var n, s = ""; ring[head] = msg.data + "\n"; head = (head + 1) % 50; if (tail == head) tail = (tail + 1) % 50; n = tail; do { s = s + ring[n]; n = (n + 1) % 50; } while (n != head); document.getElementById("r").value = s; document.getElementById("r").scrollTop = document.getElementById("r").scrollHeight; } ws.onclose = function(){ document.getElementById("m").disabled = 1; document.getElementById("b").disabled = 1; } } catch(exception) { alert('<p>Error' + exception); } </script> </html>