WebSockets - การเปิดการเชื่อมต่อ

เมื่อสร้างการเชื่อมต่อระหว่างไคลเอนต์และเซิร์ฟเวอร์แล้วเหตุการณ์เปิดจะเริ่มทำงานจากอินสแตนซ์ Web Socket เรียกว่าเป็นการจับมือครั้งแรกระหว่างไคลเอนต์และเซิร์ฟเวอร์

เหตุการณ์ที่เกิดขึ้นเมื่อสร้างการเชื่อมต่อแล้วเรียกว่า onopen. การสร้างการเชื่อมต่อ Web Socket นั้นง่ายมาก สิ่งที่คุณต้องทำคือโทรไปที่ไฟล์WebSocket constructor และส่งผ่าน URL ของเซิร์ฟเวอร์ของคุณ

รหัสต่อไปนี้ใช้เพื่อสร้างการเชื่อมต่อ Web Socket -

// Create a new WebSocket.
var socket = new WebSocket('ws://echo.websocket.org');

เมื่อสร้างการเชื่อมต่อแล้วเหตุการณ์เปิดจะเริ่มทำงานบนอินสแตนซ์ Web Socket ของคุณ

onopen หมายถึงการจับมือกันครั้งแรกระหว่างไคลเอนต์และเซิร์ฟเวอร์ซึ่งนำไปสู่การตกลงครั้งแรกและเว็บแอปพลิเคชันพร้อมที่จะส่งข้อมูล

ข้อมูลโค้ดต่อไปนี้อธิบายถึงการเปิดการเชื่อมต่อของโปรโตคอล Web Socket -

socket.onopen = function(event) {
   console.log(“Connection established”);
   // Display user friendly messages for the successful establishment of connection
   var.label = document.getElementById(“status”);
   label.innerHTML = ”Connection established”;
}

เป็นแนวทางปฏิบัติที่ดีในการให้ข้อเสนอแนะที่เหมาะสมแก่ผู้ใช้ที่รอการสร้างการเชื่อมต่อ Web Socket อย่างไรก็ตามเป็นที่สังเกตเสมอว่าการเชื่อมต่อ Web Socket นั้นค่อนข้างเร็ว

การสาธิตการเชื่อมต่อเว็บซ็อกเก็ตที่สร้างขึ้นมีการบันทึกไว้ใน URL ที่กำหนด - https://www.websocket.org/echo.html

ภาพรวมของการสร้างการเชื่อมต่อและการตอบสนองต่อผู้ใช้แสดงอยู่ด้านล่าง -

การสร้างสถานะเปิดทำให้สามารถสื่อสารและถ่ายโอนข้อความแบบดูเพล็กซ์เต็มรูปแบบได้จนกว่าการเชื่อมต่อจะสิ้นสุด

ตัวอย่าง

สร้างไฟล์ Client-HTML5

<!DOCTYPE html>
<html>
   <meta charset = "utf-8" />
   <title>WebSocket Test</title>

   <script language = "javascript" type = "text/javascript">
      var wsUri = "ws://echo.websocket.org/";
      var output;
	
      function init() {
         output = document.getElementById("output");
         testWebSocket();
      }
	
      function testWebSocket() {
         websocket = new WebSocket(wsUri);
			
         websocket.onopen = function(evt) {
            onOpen(evt)
         };
      }
	
      function onOpen(evt) {
         writeToScreen("CONNECTED");
      }
	
      window.addEventListener("load", init, false);
   
   </script>

   <h2>WebSocket Test</h2>
   <div id = "output"></div>

</html>

ผลลัพธ์จะเป็นดังนี้ -

ไฟล์ HTML5 และ JavaScript ด้านบนแสดงการใช้งานสองเหตุการณ์ของ Web Socket ได้แก่ -

  • onLoad ซึ่งช่วยในการสร้างวัตถุ JavaScript และการเริ่มต้นการเชื่อมต่อ

  • onOpen สร้างการเชื่อมต่อกับเซิร์ฟเวอร์และส่งสถานะ