WebSockets - त्रुटियों को संभालना

एक बार क्लाइंट और सर्वर के बीच एक कनेक्शन स्थापित हो जाने के बाद, ए openईवेंट वेब सॉकेट आवृत्ति से निकाल दिया गया है। गलतियों के लिए त्रुटि उत्पन्न होती है, जो संचार के दौरान होती है। की सहायता से इसे चिन्हित किया जाता हैonerror प्रतिस्पर्धा। Onerror हमेशा कनेक्शन की समाप्ति के बाद होता है।

onerrorसंचार के बीच कुछ गलत होने पर घटना को निकाल दिया जाता है। घटनाonerror एक कनेक्शन समाप्ति के बाद है, जो एक है close प्रतिस्पर्धा।

एक अच्छा अभ्यास हमेशा उपयोगकर्ता को अप्रत्याशित त्रुटि के बारे में सूचित करना और उन्हें फिर से जोड़ने का प्रयास करना है।

socket.onclose = function(event) {
   console.log("Error occurred.");
	
   // Inform the user about the error.
   var label = document.getElementById("status-label");
   label.innerHTML = "Error: " + event;
}

जब त्रुटि से निपटने की बात आती है, तो आपको आंतरिक और बाहरी दोनों मापदंडों पर विचार करना होगा।

  • आंतरिक मापदंडों में ऐसी त्रुटियां शामिल हैं जो आपके कोड में बग्स, या अप्रत्याशित उपयोगकर्ता व्यवहार के कारण उत्पन्न हो सकती हैं।

  • बाहरी त्रुटियों का आवेदन से कोई लेना-देना नहीं है; बल्कि, वे मापदंडों से संबंधित हैं, जिन्हें नियंत्रित नहीं किया जा सकता है। सबसे महत्वपूर्ण एक नेटवर्क कनेक्टिविटी है।

  • किसी भी इंटरैक्टिव बिडायरेक्शनल वेब एप्लिकेशन के लिए आवश्यक है, ठीक है, एक सक्रिय इंटरनेट कनेक्शन।

नेटवर्क उपलब्धता की जाँच करना

कल्पना करें कि आपके उपयोगकर्ता आपके वेब ऐप का आनंद ले रहे हैं, जब अचानक नेटवर्क कनेक्शन उनके कार्य के बीच में अनुत्तरदायी हो जाता है। आधुनिक देशी डेस्कटॉप और मोबाइल एप्लिकेशन में, नेटवर्क उपलब्धता के लिए जाँच करना एक सामान्य कार्य है।

ऐसा करने का सबसे आम तरीका बस एक वेबसाइट के लिए HTTP अनुरोध करना है जो माना जाता है (उदाहरण के लिए, http://www.google.com)। यदि अनुरोध सफल होता है, तो डेस्कटॉप या मोबाइल डिवाइस जानता है कि सक्रिय कनेक्टिविटी है। इसी तरह, HTML हैXMLHttpRequest नेटवर्क उपलब्धता का निर्धारण करने के लिए।

HTML5, हालांकि, इसे और भी आसान बना दिया और यह जांचने का एक तरीका पेश किया कि क्या ब्राउज़र वेब प्रतिक्रियाओं को स्वीकार कर सकता है। यह नाविक वस्तु के माध्यम से प्राप्त किया जाता है -

if (navigator.onLine) {
   alert("You are Online");
}else {
   alert("You are Offline");
}

ऑफ़लाइन मोड का अर्थ है कि या तो डिवाइस कनेक्ट नहीं है या उपयोगकर्ता ने ब्राउज़र टूलबार से ऑफ़लाइन मोड का चयन किया है।

यहां बताया गया है कि उपयोगकर्ता को कैसे सूचित किया जा सकता है कि नेटवर्क उपलब्ध नहीं है और वेबसकेट बंद होने की घटना होने पर पुन: कनेक्ट करने का प्रयास करें -

socket.onclose = function (event) {
   // Connection closed.
   // Firstly, check the reason.
	
   if (event.code != 1000) {
      // Error code 1000 means that the connection was closed normally.
      // Try to reconnect.
		
      if (!navigator.onLine) {
         alert("You are offline. Please connect to the Internet and try again.");
      }
   }
}

त्रुटि संदेश प्राप्त करने के लिए डेमो

निम्नलिखित कार्यक्रम बताते हैं कि वेब सॉकेट्स का उपयोग करके त्रुटि संदेश कैसे दिखाया जाए -

<!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)
         };
			
         websocket.onclose = function(evt) {
            onClose(evt)
         };
			
         websocket.onerror = function(evt) {
            onError(evt)
         };
      }
		
      function onOpen(evt) {
         writeToScreen("CONNECTED");
         doSend("WebSocket rocks");
      }
		
      function onClose(evt) {
         writeToScreen("DISCONNECTED");
      }
		
      function onError(evt) {
         writeToScreen('<span style = "color: red;">ERROR:</span> ' + evt.data);
      } 
		
      function doSend(message) {
         writeToScreen("SENT: " + message); websocket.send(message);
      }
		
      function writeToScreen(message) {
         var pre = document.createElement("p"); 
         pre.style.wordWrap = "break-word"; 
         pre.innerHTML = message; output.appendChild(pre);
      }
		
      window.addEventListener("load", init, false);
   </script>
	
   <h2>WebSocket Test</h2>
   <div id = "output"></div>
	
</html>

आउटपुट इस प्रकार है -