本地測試websocket連接通信案例

本文不對websocket作詳細介紹,需要具體瞭解的童鞋請自己查資料。

直接上圖:

圖片

代碼如下:

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="utf-8" />
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<meta name="viewport" content="width=device-width, initial-scale=1">
		<title>本地websocket測試</title>
		<meta name="robots" content="all" />
		<meta name="keywords" content="本地,websocket,測試工具" />
		<meta name="description" content="本地,websocket,測試工具" />
		<style>
			.btn-group{
				display: inline-block;
			}
		</style>
	</head>
	<body>
		<input type='text' value='通信地址, ws://開頭..' class="form-control" style='width:390px;display:inline'
		 id='wsaddr' />
		<div class="btn-group" >
			<button type="button" class="btn btn-default" onclick='addsocket();'>連接</button>
			<button type="button" class="btn btn-default" onclick='closesocket();'>斷開</button>
			<button type="button" class="btn btn-default" onclick='$("#wsaddr").val("")'>清空</button>
		</div>
		<div class="row">
			<div id="output" style="border:1px solid #ccc;height:365px;overflow: auto;margin: 20px 0;"></div>
			<input type="text" id='message' class="form-control" style='width:810px' placeholder="待發信息" onkeydown="en(event);">
			<span class="input-group-btn">
				<button class="btn btn-default" type="button" onclick="doSend();">發送</button>
			</span>
			</div>
		</div>
	</body>		
		
		<script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
		<script language="javascript" type="text/javascript">
			function formatDate(now) {
				var year = now.getFullYear();
				var month = now.getMonth() + 1;
				var date = now.getDate();
				var hour = now.getHours();
				var minute = now.getMinutes();
				var second = now.getSeconds();
				return year + "-" + (month = month < 10 ? ("0" + month) : month) + "-" + (date = date < 10 ? ("0" + date) : date) +
					" " + (hour = hour < 10 ? ("0" + hour) : hour) + ":" + (minute = minute < 10 ? ("0" + minute) : minute) + ":" + (
						second = second < 10 ? ("0" + second) : second);
			}
			var output;
			var websocket;

			function init() {
				output = document.getElementById("output");
				testWebSocket();
			}

			function addsocket() {
				var wsaddr = $("#wsaddr").val();
				if (wsaddr == '') {
					alert("請填寫websocket的地址");
					return false;
				}
				StartWebSocket(wsaddr);
			}

			function closesocket() {
				websocket.close();
			}

			function StartWebSocket(wsUri) {
				websocket = new WebSocket(wsUri);
				websocket.onopen = function(evt) {
					onOpen(evt)
				};
				websocket.onclose = function(evt) {
					onClose(evt)
				};
				websocket.onmessage = function(evt) {
					onMessage(evt)
				};
				websocket.onerror = function(evt) {
					onError(evt)
				};
			}

			function onOpen(evt) {
				writeToScreen("<span style='color:red'>連接成功,現在你可以發送信息啦!!!</span>");
			}

			function onClose(evt) {
				writeToScreen("<span style='color:red'>websocket連接已斷開!!!</span>");
				websocket.close();
			}

			function onMessage(evt) {
				writeToScreen('<span style="color:blue">服務端迴應&nbsp;' + formatDate(new Date()) + '</span><br/><span class="bubble">' +
					evt.data + '</span>');
			}

			function onError(evt) {
				writeToScreen('<span style="color: red;">發生錯誤:</span> ' + evt.data);
			}

			function doSend() {
				var message = $("#message").val();
				if (message == '') {
					alert("請先填寫發送信息");
					$("#message").focus();
					return false;
				}
				if (typeof websocket === "undefined") {
					alert("websocket還沒有連接,或者連接失敗,請檢測");
					return false;
				}
				if (websocket.readyState == 3) {
					alert("websocket已經關閉,請重新連接");
					return false;
				}
				console.log(websocket);
				$("#message").val('');
				writeToScreen('<span style="color:green">你發送的信息&nbsp;' + formatDate(new Date()) + '</span><br/>' + message);
				websocket.send(message);
			}

			function writeToScreen(message) {
				var div = "<div class='newmessage'>" + message + "</div>";
				var d = $("#output");
				var d = d[0];
				var doScroll = d.scrollTop == d.scrollHeight - d.clientHeight;
				$("#output").append(div);
				if (doScroll) {
					d.scrollTop = d.scrollHeight - d.clientHeight;
				}
			}


			function en(event) {
				var evt = evt ? evt : (window.event ? window.event : null);
				if (evt.keyCode == 13) {
					doSend()
				}
			}
		</script>

</html>

首先要建立通信:

var websocket = new WebSocket(wsUri);  //wsUri通信地址

常用命令:

websocket.onopen = function()  //連接的回調

websocket.onclose = function()  //關閉的回調

websocket.onmessage = function()  //服務器的響應回調

websocket.onError= function()  //發生錯誤的回調

websocket.send(message); //發送信息

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章