WebSockets - एक कनेक्शन बंद करना
Closeईवेंट सर्वर और क्लाइंट के बीच संचार के अंत को चिह्नित करता है। की मदद से कनेक्शन बंद करना संभव हैoncloseप्रतिस्पर्धा। की मदद से संचार के अंत को चिह्नित करने के बादoncloseघटना, कोई संदेश आगे सर्वर और क्लाइंट के बीच स्थानांतरित नहीं किया जा सकता है। खराब कनेक्टिविटी के कारण भी इवेंट बंद हो सकता है।
close() विधि के लिए खड़ा है goodbye handshake। यह कनेक्शन को समाप्त कर देता है और जब तक कनेक्शन फिर से नहीं खुलता तब तक किसी भी डेटा का आदान-प्रदान नहीं किया जा सकता।
पिछले उदाहरण के समान, हम कहते हैं close() विधि जब उपयोगकर्ता दूसरे बटन पर क्लिक करता है।
var textView = document.getElementById("text-view");
var buttonStop = document.getElementById("stop-button");
buttonStop.onclick = function() {
// Close the connection, if open.
if (socket.readyState === WebSocket.OPEN) {
socket.close();
}
}
नीचे बताए अनुसार हमने पहले बताए गए कोड और कारण मापदंडों को पारित करना संभव है।
socket.close(1000, "Deliberate disconnection");
निम्न कोड वेब सॉकेट कनेक्शन को बंद या डिस्कनेक्ट करने के तरीके का पूरा अवलोकन देता है -
<!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.onmessage = function(evt) {
onMessage(evt)
};
websocket.onerror = function(evt) {
onError(evt)
};
}
function onOpen(evt) {
writeToScreen("CONNECTED");
doSend("WebSocket rocks");
}
function onClose(evt) {
writeToScreen("DISCONNECTED");
}
function onMessage(evt) {
writeToScreen('<span style = "color: blue;">RESPONSE: ' +
evt.data+'</span>'); websocket.close();
}
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>
आउटपुट इस प्रकार है -