WebSockets - त्वरित गाइड
शाब्दिक शब्दों में, हाथ मिलाने को अभिवादन, बधाई, समझौते या विदाई के प्रतीक के रूप में, दो व्यक्तियों द्वारा दाहिने हाथों को पकड़ना और हिलाना के रूप में परिभाषित किया जा सकता है। कंप्यूटर विज्ञान में, हैंडशेकिंग एक ऐसी प्रक्रिया है जो सुनिश्चित करती है कि सर्वर अपने ग्राहकों के साथ तालमेल बैठाए। हैंडशेकिंग वेब सॉकेट प्रोटोकॉल की मूल अवधारणा है।
निम्नलिखित आरेख विभिन्न क्लाइंट्स के साथ सर्वर हैंडशेक दिखाता है -
वेब सॉकेट्स - परिभाषा
वेब सॉकेट को सर्वर और क्लाइंट के बीच दो-तरफ़ा संचार के रूप में परिभाषित किया जाता है, जिसका अर्थ है कि दोनों पक्ष एक ही समय में डेटा का संचार और आदान-प्रदान करते हैं।
वेब सॉकेट्स के प्रमुख बिंदु हैं true concurrency तथा optimization of performanceजिसके परिणामस्वरूप अधिक संवेदनशील और समृद्ध वेब अनुप्रयोग हैं।
वेब सॉकेट प्रोटोकॉल का विवरण
यह प्रोटोकॉल जमीन से पूर्ण द्वैध संचार को परिभाषित करता है। वेब सॉकेट वेब ब्राउज़र में डेस्कटॉप रिच फंक्शंस लाने में एक कदम आगे ले जाता है। यह एक विकास का प्रतिनिधित्व करता है, जो ग्राहक / सर्वर वेब प्रौद्योगिकी में लंबे समय से प्रतीक्षित था।
वेब सॉकेट की मुख्य विशेषताएं इस प्रकार हैं -
वेब सॉकेट प्रोटोकॉल को मानकीकृत किया जा रहा है, जिसका अर्थ है कि इस प्रोटोकॉल की मदद से वेब सर्वर और क्लाइंट के बीच वास्तविक समय का संचार संभव है।
वेब सॉकेट क्लाइंट और सर्वर के बीच वास्तविक समय संचार के लिए प्लेटफ़ॉर्म मानक को बदल रहे हैं।
यह मानक नए प्रकार के अनुप्रयोगों को सक्षम बनाता है। रीयल टाइम वेब एप्लिकेशन के लिए व्यवसाय इस तकनीक की सहायता से गति प्रदान कर सकते हैं।
वेब सॉकेट का सबसे बड़ा लाभ यह है कि यह एकल टीसीपी कनेक्शन पर दो-तरफ़ा संचार (पूर्ण द्वैध) प्रदान करता है।
यूआरएल
HTTP में http और https जैसे स्कीमा का अपना सेट है। वेब सॉकेट प्रोटोकॉल में भी इसी तरह का स्कीमा है जो अपने URL पैटर्न में परिभाषित है।
निम्न छवि टोकन में वेब सॉकेट URL दिखाती है।
ब्राउज़र का समर्थन
वेब सॉकेट प्रोटोकॉल के नवीनतम विनिर्देश को परिभाषित किया गया है RFC 6455 - एक प्रस्तावित मानक।
RFC 6455 इंटरनेट एक्सप्लोरर, मोज़िला फ़ायरफ़ॉक्स, गूगल क्रोम, सफारी और ओपेरा जैसे विभिन्न ब्राउज़रों द्वारा समर्थित है।
वेब सॉकेट्स की आवश्यकता के लिए गोता लगाने से पहले, मौजूदा तकनीकों पर एक नज़र डालना आवश्यक है, जिनका उपयोग किया जाता है duplex communicationसर्वर और क्लाइंट के बीच। वे इस प्रकार हैं -
- Polling
- लंबा मतदान
- Streaming
- पोस्टबैक और AJAX
- HTML5
मतदान
मतदान को एक विधि के रूप में परिभाषित किया जा सकता है, जो संचरण में मौजूद डेटा की परवाह किए बिना समय-समय पर अनुरोध करता है। आवधिक अनुरोधों को एक समकालिक तरीके से भेजा जाता है। क्लाइंट एक निर्दिष्ट समय अंतराल में सर्वर से आवधिक अनुरोध करता है। सर्वर की प्रतिक्रिया में उपलब्ध डेटा या इसमें कुछ चेतावनी संदेश शामिल हैं।
लंबा मतदान
लंबे मतदान, जैसा कि नाम से पता चलता है, इसमें मतदान जैसी ही तकनीक शामिल है। क्लाइंट और सर्वर तब तक कनेक्शन को सक्रिय रखते हैं जब तक कि कुछ डेटा नहीं मिलता है या टाइमआउट नहीं होता है। यदि कुछ कारणों से कनेक्शन खो गया है, तो ग्राहक अनुक्रमिक अनुरोध शुरू कर सकता है।
मतदान प्रक्रिया के दौरान प्रदर्शन में सुधार के अलावा लंबा मतदान कुछ भी नहीं है, लेकिन निरंतर अनुरोध प्रक्रिया को धीमा कर सकते हैं।
स्ट्रीमिंग
इसे रियल-टाइम डेटा ट्रांसमिशन के लिए सबसे अच्छा विकल्प माना जाता है। सर्वर क्लाइंट के साथ तब तक खुला और सक्रिय रहता है जब तक और आवश्यक डेटा प्राप्त नहीं किया जा रहा है। इस मामले में, कनेक्शन अनिश्चित काल के लिए खुला होना कहा जाता है। स्ट्रीमिंग में HTTP हेडर शामिल हैं जो फ़ाइल का आकार बढ़ाता है, जिससे देरी बढ़ जाती है। इसे एक बड़ी खामी माना जा सकता है।
ajax
AJAX जावास्क्रिप्ट पर आधारित है XmlHttpRequestवस्तु। यह एसिंक्रोनस जावास्क्रिप्ट और XML का संक्षिप्त रूप है।XmlHttpRequestऑब्जेक्ट पूरे वेब पेज को फिर से लोड किए बिना जावास्क्रिप्ट के निष्पादन की अनुमति देता है। AJAX वेब पेज का केवल एक भाग भेजता और प्राप्त करता है।
AJAX के कोड स्निपेट के साथ कॉल करें XmlHttpRequest वस्तु इस प्रकार है -
var xhttp;
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else {
// code for IE6, IE5
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
की प्रमुख कमियां AJAX की तुलना में Web Sockets हैं -
- वे HTTP हेडर भेजते हैं, जो कुल आकार को बड़ा बनाता है।
- संचार आधा द्वैध है।
- वेब सर्वर अधिक संसाधनों की खपत करता है।
एचटीएमएल 5
HTML5 वेब अनुप्रयोगों के विकास और डिजाइन के लिए एक मजबूत ढांचा है। मुख्य स्तंभों में शामिल हैंMark-up, CSS3 तथा Javascript साथ में एपीआई।
निम्न आरेख HTML5 घटक दिखाता है -
नीचे दिया गया कोड स्निपेट HTML5 की घोषणा और इसके सिद्धांत का वर्णन करता है।
<!DOCTYPE html>
हमें वेब सॉकेट की आवश्यकता क्यों है?
इंटरनेट को हाइपरटेक्स्ट मार्क-अप लैंग्वेज (एचटीएमएल) पृष्ठों का एक संग्रह माना जाता था, जो एक दूसरे को सूचना के वैचारिक जाल के रूप में जोड़ते हैं। समय के दौरान, स्थिर संसाधन संख्या और समृद्ध वस्तुओं में बढ़ गए, जैसे कि चित्र और वेब फैब्रिक का एक हिस्सा बनना शुरू हुआ।
सर्वर प्रौद्योगिकियां उन्नत हुईं जिन्होंने डायनेमिक सर्वर पेजों की अनुमति दी - वे पृष्ठ जिनकी सामग्री क्वेरी के आधार पर बनाई गई थी।
जल्द ही, और अधिक गतिशील वेब पेजों की आवश्यकता के लिए डायनामिक हाइपरटेक्स्ट मार्क-अप लैंग्वेज (DHTML) की उपलब्धता हो सकती है। सभी जावास्क्रिप्ट के लिए धन्यवाद। अगले वर्षों में, हमने देखाcross frame communication इसके बाद पृष्ठ पुनः लोड से बचने के प्रयास में HTTP Polling फ्रेम के भीतर।
हालांकि, इनमें से किसी भी समाधान ने सर्वर और क्लाइंट के बीच वास्तविक समय द्वि-दिशात्मक संचार के लिए वास्तव में मानकीकृत क्रॉस ब्राउज़र समाधान की पेशकश नहीं की।
इसने वेब सॉकेट्स प्रोटोकॉल की आवश्यकता को जन्म दिया। इसने फुल-डुप्लेक्स संचार को जन्म दिया जिससे सभी वेब ब्राउज़रों के लिए डेस्कटॉप-समृद्ध कार्यक्षमता आ गई।
वेब सॉकेट वेब संचार के इतिहास में एक प्रमुख उन्नयन का प्रतिनिधित्व करता है। इसके अस्तित्व से पहले, वेब क्लाइंट और सर्वर के बीच सभी संचार केवल HTTP पर निर्भर थे।
वेब सॉकेट उन कनेक्शनों के गतिशील प्रवाह में मदद करता है जो लगातार पूर्ण द्वैध हैं। पूर्ण द्वैध काफी तेज गति के साथ दोनों सिरों से संचार को संदर्भित करता है।
मौजूदा प्रोटोकॉल की सभी कमियों को दूर करने की अपनी दक्षता के कारण इसे गेम चेंजर कहा जाता है।
डेवलपर्स और आर्किटेक्ट्स के लिए वेब सॉकेट
डेवलपर्स और वास्तुकारों के लिए वेब सॉकेट का महत्व -
वेब सॉकेट एक स्वतंत्र टीसीपी आधारित प्रोटोकॉल है, लेकिन इसे किसी भी अन्य प्रोटोकॉल का समर्थन करने के लिए डिज़ाइन किया गया है जो परंपरागत रूप से केवल शुद्ध टीसीपी कनेक्शन के शीर्ष पर चलेगा।
वेब सॉकेट एक ट्रांसपोर्ट लेयर है जिसके ऊपर कोई भी अन्य प्रोटोकॉल चल सकता है। वेब सॉकेट एपीआई उप-प्रोटोकॉल को परिभाषित करने की क्षमता का समर्थन करता है: प्रोटोकॉल पुस्तकालय जो विशिष्ट प्रोटोकॉल की व्याख्या कर सकते हैं।
ऐसे प्रोटोकॉल के उदाहरणों में XMPP, STOMP और AMQP शामिल हैं। डेवलपर्स को अब HTTP अनुरोध-प्रतिक्रिया प्रतिमान के संदर्भ में सोचने की ज़रूरत नहीं है।
ब्राउज़र-साइड पर एकमात्र आवश्यकता एक जावास्क्रिप्ट लाइब्रेरी चलाने की है जो वेब सॉकेट हैंडशेक की व्याख्या कर सकती है, वेब सॉकेट कनेक्शन को स्थापित और बनाए रख सकती है।
सर्वर की ओर, उद्योग मानक मौजूदा प्रोटोकॉल पुस्तकालयों का उपयोग करने के लिए है जो टीसीपी के शीर्ष पर चलते हैं और वेब सॉकेट गेटवे का लाभ उठाते हैं।
निम्नलिखित आरेख वेब सॉकेट्स की कार्यक्षमता का वर्णन करता है -
वेब सॉकेट कनेक्शन HTTP के माध्यम से शुरू किए जाते हैं; HTTP सर्वर आमतौर पर अपग्रेड अनुरोध के रूप में वेब सॉकेट हैंडशेक की व्याख्या करते हैं।
वेब सॉकेट्स मौजूदा HTTP वातावरण के पूरक ऐड-ऑन हो सकते हैं और वेब कार्यक्षमता को जोड़ने के लिए आवश्यक बुनियादी ढाँचा प्रदान कर सकते हैं। यह अधिक उन्नत, पूर्ण द्वैध प्रोटोकॉल पर निर्भर करता है जो डेटा को क्लाइंट और सर्वर के बीच दोनों दिशाओं में प्रवाह करने की अनुमति देता है।
वेब सॉकेट्स के कार्य
वेब सॉकेट वेब सर्वर और क्लाइंट के बीच एक संबंध प्रदान करता है, ताकि दोनों पक्ष डेटा भेजना शुरू कर सकें।
वेब सॉकेट के कनेक्शन को स्थापित करने के लिए कदम इस प्रकार हैं -
क्लाइंट वेब सॉकेट हैंडशेक नामक एक प्रक्रिया के माध्यम से एक कनेक्शन स्थापित करता है।
प्रक्रिया क्लाइंट के साथ शुरू होती है जो सर्वर पर एक नियमित HTTP अनुरोध भेजती है।
एक अपग्रेड हेडर का अनुरोध किया जाता है। इस अनुरोध में, यह सर्वर को सूचित करता है कि अनुरोध वेब सॉकेट कनेक्शन के लिए है।
वेब सॉकेट URL का उपयोग करते हैं wsयोजना। वे सुरक्षित वेब सॉकेट कनेक्शन के लिए भी उपयोग किए जाते हैं, जो HTTP के बराबर हैं।
प्रारंभिक अनुरोध हेडर का एक सरल उदाहरण इस प्रकार है -
GET ws://websocket.example.com/ HTTP/1.1
Origin: http://example.com
Connection: Upgrade
Host: websocket.example.com
Upgrade: websocket
वेब सॉकेट न केवल वेब बल्कि मोबाइल उद्योग में भी एक महत्वपूर्ण भूमिका रखता है। वेब सॉकेट का महत्व नीचे दिया गया है।
जैसा कि नाम इंगित करता है वेब सॉकेट, वेब से संबंधित हैं। वेब में कुछ ब्राउज़रों के लिए तकनीकों का एक समूह होता है; यह डेस्कटॉप कंप्यूटर, लैपटॉप, टैबलेट और स्मार्ट फोन सहित बड़ी संख्या में उपकरणों के लिए एक व्यापक संचार मंच है।
HTML5 ऐप जो वेब सॉकेट का उपयोग करता है, किसी भी HTML5 सक्षम वेब ब्राउज़र पर काम करेगा।
वेब सॉकेट मुख्यधारा की ऑपरेटिंग सिस्टम में समर्थित है। मोबाइल उद्योग के सभी प्रमुख खिलाड़ी अपने नेटिव ऐप्स में वेब सॉकेट एपीआई प्रदान करते हैं।
वेब सॉकेट को पूर्ण द्वैध संचार कहा जाता है। वेब सॉकेट्स का दृष्टिकोण वेब एप्लिकेशन की कुछ श्रेणियों जैसे चैट रूम के लिए अच्छी तरह से काम करता है, जहां क्लाइंट और साथ ही सर्वर से अपडेट एक साथ साझा किए जाते हैं।
वेब सॉकेट, HTML5 विनिर्देश का एक हिस्सा, वेब पृष्ठों और एक दूरस्थ होस्ट के बीच पूर्ण द्वैध संचार की अनुमति देता है। प्रोटोकॉल को निम्नलिखित लाभों को प्राप्त करने के लिए डिज़ाइन किया गया है, जिन्हें प्रमुख बिंदुओं के रूप में माना जा सकता है -
Reduce unnecessary network traffic and latency एकल कनेक्शन (दो के बजाय) के माध्यम से पूर्ण द्वैध का उपयोग करना।
Streaming through proxies and firewalls, एक साथ अपस्ट्रीम और डाउनस्ट्रीम संचार के समर्थन के साथ।
उनके बीच संचार के लिए क्लाइंट से सर्वर से कनेक्शन को इनिशियलाइज़ करना आवश्यक है। कनेक्शन को शुरू करने के लिए, रिमोट या स्थानीय सर्वर के साथ URL के साथ जावास्क्रिप्ट ऑब्जेक्ट का निर्माण आवश्यक है।
var socket = new WebSocket(“ ws://echo.websocket.org ”);
ऊपर उल्लिखित URL एक सार्वजनिक पता है जिसका उपयोग परीक्षण और प्रयोगों के लिए किया जा सकता है। Websocket.org सर्वर हमेशा ऊपर रहता है और जब वह संदेश प्राप्त करता है और क्लाइंट को वापस भेजता है।
यह सुनिश्चित करने के लिए सबसे महत्वपूर्ण कदम है कि आवेदन सही ढंग से काम करता है।
वेब सॉकेट - ईवेंट
चार मुख्य वेब सॉकेट एपीआई हैं events -
- Open
- Message
- Close
- Error
प्रत्येक घटना को कार्यों को लागू करने के द्वारा नियंत्रित किया जाता है जैसे onopen, onmessage, onclose तथा onerrorक्रमशः कार्य करता है। इसे addEventListener विधि की सहायता से भी लागू किया जा सकता है।
घटनाओं और कार्यों का संक्षिप्त विवरण निम्नानुसार है -
खुला हुआ
क्लाइंट और सर्वर के बीच कनेक्शन स्थापित हो जाने के बाद, ओपन इवेंट को वेब सॉकेट उदाहरण से निकाल दिया जाता है। इसे क्लाइंट और सर्वर के बीच प्रारंभिक हैंडशेक कहा जाता है। कनेक्शन स्थापित होने के बाद उठने वाली घटना को कहा जाता हैonopen।
संदेश
संदेश घटना आमतौर पर तब होती है जब सर्वर कुछ डेटा भेजता है। क्लाइंट को सर्वर द्वारा भेजे गए संदेशों में सादे पाठ संदेश, बाइनरी डेटा या चित्र शामिल हो सकते हैं। जब भी डेटा भेजा जाता है,onmessage समारोह निकाल दिया जाता है।
बंद करे
क्लोज इवेंट सर्वर और क्लाइंट के बीच संचार के अंत को चिह्नित करता है। की मदद से कनेक्शन बंद करना संभव हैoncloseप्रतिस्पर्धा। की मदद से संचार के अंत को चिह्नित करने के बादoncloseईवेंट, सर्वर और क्लाइंट के बीच कोई संदेश और स्थानांतरित नहीं किया जा सकता है। खराब कनेक्टिविटी के कारण भी इवेंट बंद हो सकता है।
त्रुटि
कुछ गलती के लिए त्रुटि के निशान, जो संचार के दौरान होता है। की सहायता से इसे चिन्हित किया जाता हैonerror प्रतिस्पर्धा। Onerrorहमेशा कनेक्शन की समाप्ति के बाद होता है। प्रत्येक घटना का विस्तृत वर्णन आगे के अध्यायों में किया गया है।
वेब सॉकेट्स - क्रियाएँ
जब कुछ होता है तो आमतौर पर घटनाओं को ट्रिगर किया जाता है। दूसरी ओर, जब उपयोगकर्ता कुछ करना चाहते हैं तो कार्रवाई की जाती है। उपयोगकर्ताओं द्वारा कार्यों का उपयोग करके स्पष्ट कॉल द्वारा कार्रवाई की जाती है।
वेब सॉकेट प्रोटोकॉल दो मुख्य क्रियाओं का समर्थन करता है, अर्थात् -
- भेजें ()
- बंद करे( )
भेजें ()
यह क्रिया आमतौर पर सर्वर के साथ कुछ संचार के लिए पसंद की जाती है, जिसमें संदेश भेजना शामिल होता है, जिसमें पाठ फाइलें, बाइनरी डेटा या छवियां शामिल होती हैं।
एक चैट संदेश, जो भेजने () कार्रवाई की सहायता से भेजा जाता है, इस प्रकार है -
// get text view and button for submitting the message
var textsend = document.getElementById(“text-view”);
var submitMsg = document.getElementById(“tsend-button”);
//Handling the click event
submitMsg.onclick = function ( ) {
// Send the data
socket.send( textsend.value);
}
Note - कनेक्शन खुला होने पर ही संदेश भेजना संभव है।
बंद करे ( )
यह विधि अलविदा हाथ मिलाने के लिए है। यह कनेक्शन को पूरी तरह से समाप्त कर देता है और जब तक कनेक्शन फिर से स्थापित नहीं हो जाता है, तब तक कोई डेटा स्थानांतरित नहीं किया जा सकता है।
var textsend = document.getElementById(“text-view”);
var buttonStop = document.getElementById(“stop-button”);
//Handling the click event
buttonStop.onclick = function ( ) {
// Close the connection if open
if (socket.readyState === WebSocket.OPEN){
socket.close( );
}
}
निम्नलिखित स्निपेट की सहायता से जानबूझकर कनेक्शन को बंद करना भी संभव है -
socket.close(1000,”Deliberate Connection”);
एक बार क्लाइंट और सर्वर के बीच कनेक्शन स्थापित हो जाने के बाद, ओपन इवेंट को वेब सॉकेट उदाहरण से निकाल दिया जाता है। इसे क्लाइंट और सर्वर के बीच प्रारंभिक हैंडशेक कहा जाता है।
कनेक्शन स्थापित होने के बाद उठने वाली घटना को कहा जाता है onopen। वेब सॉकेट कनेक्शन बनाना वास्तव में सरल है। आपको बस कॉल करना हैWebSocket constructor और अपने सर्वर के URL में पास करें।
वेब सॉकेट कनेक्शन बनाने के लिए निम्न कोड का उपयोग किया जाता है -
// Create a new WebSocket.
var socket = new WebSocket('ws://echo.websocket.org');
एक बार कनेक्शन स्थापित हो जाने के बाद, खुली घटना को आपके वेब सॉकेट उदाहरण पर निकाल दिया जाएगा।
onopen क्लाइंट और सर्वर के बीच शुरुआती हैंडशेक को संदर्भित करता है, जिसमें पहली डील होती है और डेटा को प्रसारित करने के लिए वेब एप्लिकेशन तैयार होता है।
निम्नलिखित कोड स्निपेट वेब सॉकेट प्रोटोकॉल के कनेक्शन को खोलने का वर्णन करता है -
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”;
}
वेब सॉकेट कनेक्शन की स्थापना के लिए प्रतीक्षा कर रहे उपयोगकर्ताओं को उचित प्रतिक्रिया प्रदान करना एक अच्छा अभ्यास है। हालांकि, यह हमेशा ध्यान दिया जाता है कि वेब सॉकेट कनेक्शन तुलनात्मक रूप से तेज हैं।
दिए गए URL में वेब सॉकेट कनेक्शन का डेमो प्रलेखित है - https://www.websocket.org/echo.html
कनेक्शन स्थापना और उपयोगकर्ता की प्रतिक्रिया का एक स्नैपशॉट नीचे दिखाया गया है -
एक खुले राज्य की स्थापना पूर्ण द्वैध संचार और संदेशों के हस्तांतरण की अनुमति देती है जब तक कि कनेक्शन समाप्त नहीं हो जाता।
उदाहरण
क्लाइंट-एचटीएमएल 5 फ़ाइल का निर्माण।
<!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 और जावास्क्रिप्ट फ़ाइल वेब सॉकेट की दो घटनाओं के कार्यान्वयन को दर्शाती है, अर्थात् -
onLoad जो जावास्क्रिप्ट ऑब्जेक्ट के निर्माण और कनेक्शन के आरंभ में मदद करता है।
onOpen सर्वर के साथ संबंध स्थापित करता है और स्थिति भी भेजता है।
एक बार क्लाइंट और सर्वर के बीच एक कनेक्शन स्थापित हो जाने के बाद, ए 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>
आउटपुट इस प्रकार है -
Messageईवेंट आमतौर पर तब होता है जब सर्वर कुछ डेटा भेजता है। क्लाइंट द्वारा सर्वर को भेजे गए संदेशों में सादा पाठ संदेश, बाइनरी डेटा या चित्र शामिल हो सकते हैं। जब भी डेटा भेजा जाता है,onmessage समारोह निकाल दिया जाता है।
यह ईवेंट सर्वर के लिए क्लाइंट के कान के रूप में कार्य करता है। जब भी सर्वर डेटा भेजता है,onmessage घटना दूर हो जाती है।
निम्न कोड स्निपेट वेब सॉकेट प्रोटोकॉल के कनेक्शन को खोलने का वर्णन करता है।
connection.onmessage = function(e){
var server_message = e.data;
console.log(server_message);
}
यह भी ध्यान में रखना आवश्यक है कि वेब सॉकेट्स की मदद से किस प्रकार के डेटा को स्थानांतरित किया जा सकता है। वेब सॉकेट प्रोटोकॉल पाठ और बाइनरी डेटा का समर्थन करता है। जावास्क्रिप्ट के संदर्भ में,text एक स्ट्रिंग के रूप में संदर्भित करता है, जबकि बाइनरी डेटा का प्रतिनिधित्व किया जाता है ArrayBuffer।
वेब सॉकेट एक समय में केवल एक बाइनरी प्रारूप का समर्थन करता है। बाइनरी डेटा की घोषणा स्पष्ट रूप से निम्नानुसार की जाती है -
socket.binaryType = ”arrayBuffer”;
socket.binaryType = ”blob”;
स्ट्रिंग्स
स्ट्रिंग्स को उपयोगी माना जाता है, एक्सएमएल और जेएसएन जैसे मानव पठनीय प्रारूपों से निपटते हैं। जब कभीonmessage ईवेंट उठाया जाता है, क्लाइंट को डेटा प्रकार की जांच करने और तदनुसार कार्य करने की आवश्यकता होती है।
स्ट्रिंग के रूप में डेटा प्रकार का निर्धारण करने के लिए कोड स्निपेट नीचे उल्लिखित है -
socket.onmessage = function(event){
if(typeOf event.data === String ) {
console.log(“Received data string”);
}
}
JSON (जावास्क्रिप्ट ऑब्जेक्ट संकेतन)
यह कंप्यूटरों के बीच मानव-पठनीय डेटा को स्थानांतरित करने के लिए एक हल्का प्रारूप है। JSON की संरचना में मुख्य-मूल्य जोड़े शामिल हैं।
उदाहरण
{
name: “James Devilson”,
message: “Hello World!”
}
निम्न कोड दिखाता है कि JSON ऑब्जेक्ट को कैसे संभालना है और इसके गुणों को निकालना है -
socket.onmessage = function(event) {
if(typeOf event.data === String ){
//create a JSON object
var jsonObject = JSON.parse(event.data);
var username = jsonObject.name;
var message = jsonObject.message;
console.log(“Received data string”);
}
}
एक्सएमएल
XML में पार्स करना मुश्किल नहीं है, हालांकि तकनीक ब्राउज़र से ब्राउज़र तक भिन्न होती है। सबसे अच्छी विधि थर्ड पार्टी लाइब्रेरी जैसे jQuery का उपयोग करके पार्स करना है।
XML और JSON दोनों में, सर्वर एक स्ट्रिंग के रूप में प्रतिक्रिया करता है, जिसे क्लाइंट अंत में पार्स किया जा रहा है।
ArrayBuffer
इसमें एक संरचित बाइनरी डेटा होता है। संलग्न बिट्स एक क्रम में दिए गए हैं ताकि स्थिति को आसानी से ट्रैक किया जा सके। ArrayBuffers छवि फ़ाइलों को संग्रहीत करने के लिए आसान है।
ArrayBuffers का उपयोग करके डेटा प्राप्त करना काफी सरल है। परिचालकinstanceOf बराबर ऑपरेटर के बजाय प्रयोग किया जाता है।
निम्न कोड दिखाता है कि एक ArrayBuffer ऑब्जेक्ट को कैसे संभालना और प्राप्त करना है -
socket.onmessage = function(event) {
if(event.data instanceof ArrayBuffer ){
var buffer = event.data;
console.log(“Received arraybuffer”);
}
}
डेमो आवेदन
निम्न प्रोग्राम कोड दिखाता है कि वेब सॉकेट का उपयोग करके संदेश कैसे भेजें और प्राप्त करें।
<!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.onmessage = function(evt) {
onMessage(evt)
};
websocket.onerror = function(evt) {
onError(evt)
};
}
function onOpen(evt) {
writeToScreen("CONNECTED");
doSend("WebSocket rocks");
}
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>
आउटपुट नीचे दिखाया गया है।
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>
आउटपुट इस प्रकार है -
एक वेब सॉकेट सर्वर एक सरल प्रोग्राम है, जिसमें वेब सॉकेट घटनाओं और कार्यों को संभालने की क्षमता है। यह आमतौर पर वेब सॉकेट क्लाइंट एपीआई के समान तरीकों को उजागर करता है और अधिकांश प्रोग्रामिंग भाषाएँ एक कार्यान्वयन प्रदान करती हैं। निम्नलिखित आरेख एक वेब सॉकेट सर्वर और एक वेब सॉकेट क्लाइंट के बीच संचार प्रक्रिया को दिखाता है, जो ट्रिगर की गई घटनाओं और कार्यों पर जोर देता है।
निम्नलिखित आरेख एक वेब सॉकेट सर्वर और क्लाइंट इवेंट ट्रिगर दिखाता है -
वेब सर्वर से कनेक्ट करना
वेब सॉकेट सर्वर वेब सॉकेट क्लाइंट के लिए समान तरीके से काम करता है। यह घटनाओं पर प्रतिक्रिया करता है और आवश्यक होने पर क्रियाएं करता है। उपयोग की गई प्रोग्रामिंग भाषा के बावजूद, हर वेब सॉकेट सर्वर कुछ विशिष्ट कार्य करता है।
यह एक वेब सॉकेट पते पर आरंभीकृत होता है। यह संभालता हैOnOpen, OnClose, तथा OnMessage घटनाओं, और ग्राहकों को संदेश भी भेजता है।
एक वेब सॉकेट सर्वर इंस्टेंस बनाना
प्रत्येक वेब सॉकेट सर्वर को एक मान्य होस्ट और पोर्ट की आवश्यकता होती है। सर्वर में एक वेब सॉकेट उदाहरण बनाने का एक उदाहरण इस प्रकार है -
var server = new WebSocketServer("ws://localhost:8181");
किसी भी मान्य URL का उपयोग पोर्ट के विनिर्देशन के साथ किया जा सकता है, जिसका उपयोग पहले नहीं किया गया था। कनेक्टेड क्लाइंट का रिकॉर्ड रखना बहुत उपयोगी है, क्योंकि यह विभिन्न डेटा के साथ विवरण प्रदान करता है या प्रत्येक को अलग-अलग संदेश भेजता है।
फ्लेक आने वाले कनेक्शन (क्लाइंट) का प्रतिनिधित्व करता है IwebSocketConnectionइंटरफेस। जब भी कोई हमारी सेवा से जुड़ता है या डिस्कनेक्ट होता है, तो खाली सूची बनाई या अपडेट की जा सकती है।
var clients = new List<IWebSocketConnection>();
उसके बाद, हम कॉल कर सकते हैं Startविधि और ग्राहकों को कनेक्ट करने के लिए प्रतीक्षा करें। शुरू करने के बाद, सर्वर आने वाले कनेक्शन को स्वीकार करने में सक्षम है। फ्लेक में, स्टार्ट विधि को एक पैरामीटर की आवश्यकता होती है, जो घटनाओं को उठाने वाले सॉकेट को इंगित करता है -
server.Start(socket) =>
{
});
ओपेन इवेंट
OnOpenघटना निर्धारित करती है कि एक नए ग्राहक ने पहुंच का अनुरोध किया है और एक प्रारंभिक हैंडशेक करता है। क्लाइंट को सूची में जोड़ा जाना चाहिए और संभवत: जानकारी को उससे संबंधित संग्रहित किया जाना चाहिए, जैसे कि आईपी पता। फ्लेक हमें इस तरह की जानकारी, साथ ही कनेक्शन के लिए एक अद्वितीय पहचानकर्ता प्रदान करता है।
server.Start(socket) ⇒ {
socket.OnOpen = () ⇒ {
// Add the incoming connection to our list.
clients.Add(socket);
}
// Handle the other events here...
});
घटना पर क्लिक करें
OnCloseजब भी किसी ग्राहक को डिस्कनेक्ट किया जाता है तो ईवेंट उठाया जाता है। क्लाइंट को सूची से हटा दिया जाता है और बाकी ग्राहकों को वियोग के बारे में सूचित करता है।
socket.OnClose = () ⇒ {
// Remove the disconnected client from the list.
clients.Remove(socket);
};
ऑनमैसेज इवेंट
OnMessageईवेंट तब उठाया जाता है जब कोई क्लाइंट सर्वर को डेटा भेजता है। इस ईवेंट हैंडलर के अंदर, आने वाले संदेश को ग्राहकों तक पहुंचाया जा सकता है, या शायद उनमें से कुछ का चयन करें।
प्रक्रिया सरल है। ध्यान दें कि यह हैंडलर नाम की एक स्ट्रिंग लेता हैmessage एक पैरामीटर के रूप में -
socket.OnMessage = () ⇒ {
// Display the message on the console.
Console.WriteLine(message);
};
भेजें () विधि
Send()विधि केवल वांछित संदेश को निर्दिष्ट क्लाइंट तक पहुंचाती है। Send (), टेक्स्ट या बाइनरी डेटा का उपयोग करके ग्राहकों को स्टोर किया जा सकता है।
का काम OnMessage घटना इस प्रकार है -
socket.OnMessage = () ⇒ {
foreach (var client in clients) {
// Send the message to everyone!
// Also, send the client connection's unique identifier in order
// to recognize who is who.
client.Send(client.ConnectionInfo.Id + " says: " + message);
}
};
एपीआई - परिभाषा
एपीआई, एप्लिकेशन प्रोग्राम इंटरफ़ेस का संक्षिप्त नाम, सॉफ्टवेयर अनुप्रयोगों के निर्माण के लिए दिनचर्या, प्रोटोकॉल और उपकरणों का एक समूह है।
कुछ महत्वपूर्ण विशेषताएं हैं -
एपीआई निर्दिष्ट करता है कि सॉफ्टवेयर घटकों को कैसे इंटरैक्ट करना चाहिए और ग्राफिक यूजर इंटरफेस (जीयूआई) घटकों को प्रोग्रामिंग करते समय एपीआई का उपयोग किया जाना चाहिए।
एक अच्छा एपीआई सभी बिल्डिंग ब्लॉक्स प्रदान करके एक प्रोग्राम विकसित करना आसान बनाता है।
आमतौर पर HTTP पर चलने वाले REST का उपयोग अक्सर मोबाइल एप्लिकेशन, सोशल वेबसाइट, मैशअप टूल और स्वचालित व्यावसायिक प्रक्रियाओं में किया जाता है।
REST शैली इस बात पर जोर देती है कि क्लाइंट और सेवाओं के बीच परस्पर क्रिया सीमित संख्या में (वर्ब्स) होने से बढ़ी है।
संसाधनों को असाइन करके लचीलापन प्रदान किया जाता है; अपने स्वयं के अनूठे यूनिवर्सल रिसोर्स आइडेंटिफ़ायर (URI)।
REST अस्पष्टता से बचता है क्योंकि प्रत्येक क्रिया का एक विशिष्ट अर्थ है (GET, POST, PUT और DELETE)
वेब सॉकेट के लाभ
वेब सॉकेट सामान्य तौर पर REST या HTTP के साथ कुछ समस्याएँ हल करता है -
द्विदिश
HTTP एक यूनिडायरेक्शनल प्रोटोकॉल है जहाँ ग्राहक हमेशा एक अनुरोध करता है। सर्वर संसाधित करता है और एक प्रतिक्रिया देता है, और फिर ग्राहक इसका उपभोग करता है। वेब सॉकेट एक द्वि-दिशात्मक प्रोटोकॉल है जहां अनुरोध / प्रतिक्रिया जैसे कोई पूर्वनिर्धारित संदेश पैटर्न नहीं हैं। या तो क्लाइंट या सर्वर दूसरी पार्टी को संदेश भेज सकते हैं।
फुल डुप्लेक्स
HTTP क्लाइंट से सर्वर पर जाने के लिए अनुरोध संदेश की अनुमति देता है और फिर सर्वर क्लाइंट को एक प्रतिक्रिया संदेश भेजता है। किसी दिए गए समय में, या तो क्लाइंट सर्वर से बात कर रहा है या सर्वर क्लाइंट से बात कर रहा है। वेब सॉकेट क्लाइंट और सर्वर को एक दूसरे से स्वतंत्र बात करने की अनुमति देता है।
सिंगल टीसीपी कनेक्शन
सामान्यतया, HTTP अनुरोध के लिए एक नया TCP कनेक्शन शुरू किया जाता है और प्रतिक्रिया प्राप्त होने के बाद समाप्त कर दिया जाता है। एक अन्य HTTP अनुरोध / प्रतिक्रिया के लिए एक नया टीसीपी कनेक्शन स्थापित करने की आवश्यकता है। वेब सॉकेट के लिए, HTTP कनेक्शन मानक HTTP अपग्रेड तंत्र और क्लाइंट का उपयोग करके अपग्रेड किया जाता है और सर्वर उसी वेब टीसीपी कनेक्शन के जीवनचक्र के लिए उसी टीसीपी कनेक्शन पर संचार करता है।
नीचे दिया गया ग्राफ एक स्थिर पेलोड आकार के लिए एन संदेशों को संसाधित करने के लिए लिया गया समय (मिलीसेकंड में) दिखाता है।
यहाँ कच्चा डेटा है जो इस ग्राफ को खिलाता है -
ऊपर दिया गया ग्राफ़ और तालिका दर्शाती है कि संदेशों की संख्या के साथ REST ओवरहेड बढ़ता है। यह सच है क्योंकि कई टीसीपी कनेक्शनों को शुरू करने और समाप्त करने की आवश्यकता है और कई HTTP हेडर को भेजने और प्राप्त करने की आवश्यकता है।
अंतिम कॉलम विशेष रूप से एक REST अनुरोध को पूरा करने के लिए समय की मात्रा के लिए गुणन कारक को दर्शाता है।
दूसरा ग्राफ पेलोड के आकार को अलग-अलग करके संदेशों की निश्चित संख्या को संसाधित करने में लगने वाले समय को दर्शाता है।
यहाँ कच्चा डेटा है जो इस ग्राफ को खिलाता है -
यह ग्राफ दिखाता है कि REST समापन बिंदु के लिए अनुरोध / प्रतिक्रिया को संसाधित करने की वृद्धिशील लागत न्यूनतम है और अधिकांश समय कनेक्शन दीक्षा / समाप्ति और HTTP शब्दार्थ को सम्मानित करने में व्यतीत होता है।
निष्कर्ष
वेब सॉकेट एक निम्न-स्तरीय प्रोटोकॉल है। एक साधारण अनुरोध / प्रतिक्रिया डिजाइन पैटर्न, कैसे बनाने / अद्यतन / हटाने के लिए संसाधनों की जरूरत है, स्थिति कोड आदि सहित सब कुछ, इसके शीर्ष पर बनाता है। ये सभी HTTP के लिए अच्छी तरह से परिभाषित हैं।
वेब सॉकेट एक स्टेटफुल प्रोटोकॉल है जबकि HTTP एक स्टेटलेस प्रोटोकॉल है। वेब सॉकेट कनेक्शन एकल सर्वर पर लंबवत पैमाने पर हो सकता है जबकि HTTP क्षैतिज रूप से स्केल कर सकता है। वेब सॉकेट क्षैतिज स्केलिंग के लिए कुछ मालिकाना समाधान हैं, लेकिन वे मानकों पर आधारित नहीं हैं। HTTP कई अन्य अच्छाइयों जैसे कैशिंग, रूटिंग और मल्टीप्लेक्सिंग के साथ आता है। इन सभी को वेब सॉकेट के शीर्ष पर परिभाषित करने की आवश्यकता है।
निम्नलिखित प्रोग्राम कोड में जावास्क्रिप्ट और वेब सॉकेट प्रोटोकॉल का उपयोग करते हुए एक चैट एप्लिकेशन के काम का वर्णन किया गया है।
<!DOCTYPE html>
<html lang = "en">
<head>
<meta charset = utf-8>
<title>HTML5 Chat</title>
<body>
<section id = "wrapper">
<header>
<h1>HTML5 Chat</h1>
</header>
<style>
#chat { width: 97%; }
.message { font-weight: bold; }
.message:before { content: ' '; color: #bbb; font-size: 14px; }
#log {
overflow: auto;
max-height: 300px;
list-style: none;
padding: 0;
}
#log li {
border-top: 1px solid #ccc;
margin: 0;
padding: 10px 0;
}
body {
font: normal 16px/20px "Helvetica Neue", Helvetica, sans-serif;
background: rgb(237, 237, 236);
margin: 0;
margin-top: 40px;
padding: 0;
}
section, header {
display: block;
}
#wrapper {
width: 600px;
margin: 0 auto;
background: #fff;
border-radius: 10px;
border-top: 1px solid #fff;
padding-bottom: 16px;
}
h1 {
padding-top: 10px;
}
h2 {
font-size: 100%;
font-style: italic;
}
header, article > * {
margin: 20px;
}
#status {
padding: 5px;
color: #fff;
background: #ccc;
}
#status.fail {
background: #c00;
}
#status.success {
background: #0c0;
}
#status.offline {
background: #c00;
}
#status.online {
background: #0c0;
}
#html5badge {
margin-left: -30px;
border: 0;
}
#html5badge img {
border: 0;
}
</style>
<article>
<form onsubmit = "addMessage(); return false;">
<input type = "text" id = "chat" placeholder = "type and press
enter to chat" />
</form>
<p id = "status">Not connected</p>
<p>Users connected: <span id = "connected">0
</span></p>
<ul id = "log"></ul>
</article>
<script>
connected = document.getElementById("connected");
log = document.getElementById("log");
chat = document.getElementById("chat");
form = chat.form;
state = document.getElementById("status");
if (window.WebSocket === undefined) {
state.innerHTML = "sockets not supported";
state.className = "fail";
}else {
if (typeof String.prototype.startsWith != "function") {
String.prototype.startsWith = function (str) {
return this.indexOf(str) == 0;
};
}
window.addEventListener("load", onLoad, false);
}
function onLoad() {
var wsUri = "ws://127.0.0.1:7777";
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) {
state.className = "success";
state.innerHTML = "Connected to server";
}
function onClose(evt) {
state.className = "fail";
state.innerHTML = "Not connected";
connected.innerHTML = "0";
}
function onMessage(evt) {
// There are two types of messages:
// 1. a chat participant message itself
// 2. a message with a number of connected chat participants
var message = evt.data;
if (message.startsWith("log:")) {
message = message.slice("log:".length);
log.innerHTML = '<li class = "message">' +
message + "</li>" + log.innerHTML;
}else if (message.startsWith("connected:")) {
message = message.slice("connected:".length);
connected.innerHTML = message;
}
}
function onError(evt) {
state.className = "fail";
state.innerHTML = "Communication error";
}
function addMessage() {
var message = chat.value;
chat.value = "";
websocket.send(message);
}
</script>
</section>
</body>
</head>
</html>
मुख्य विशेषताएं और चैट एप्लिकेशन के आउटपुट की चर्चा नीचे की गई है -
परीक्षण करने के लिए, वेब सॉकेट समर्थन के साथ दो विंडो खोलें, ऊपर एक संदेश टाइप करें और रिटर्न दबाएं। यह चैट एप्लिकेशन की सुविधा को सक्षम करेगा।
यदि कनेक्शन स्थापित नहीं है, तो आउटपुट नीचे दिखाए गए अनुसार उपलब्ध है।
एक सफल चैट संचार का आउटपुट नीचे दिखाया गया है।
वेब को बड़े पैमाने पर HTTP के अनुरोध / प्रतिक्रिया प्रतिमान के आसपास बनाया गया है। एक ग्राहक वेब पेज को लोड करता है और तब तक कुछ नहीं होता जब तक उपयोगकर्ता अगले पृष्ठ पर क्लिक नहीं करता। 2005 के आसपास, AJAX ने वेब को अधिक गतिशील महसूस करना शुरू कर दिया। फिर भी, सभी HTTP संचार क्लाइंट द्वारा संचालित किया जाता है, जिसमें सर्वर से नए डेटा को लोड करने के लिए उपयोगकर्ता इंटरैक्शन या आवधिक मतदान की आवश्यकता होती है।
ऐसी तकनीकें जो सर्वर को उसी क्षण ग्राहक को डेटा भेजने में सक्षम बनाती हैं, जब उसे पता होता है कि नया डेटा उपलब्ध है, लगभग कुछ समय से है। वे जैसे नामों से जाते हैं"Push" या “Comet”।
साथ में long polling, क्लाइंट सर्वर से एक HTTP कनेक्शन खोलता है, जो प्रतिक्रिया भेजने तक इसे खुला रखता है। जब भी सर्वर में वास्तव में नया डेटा होता है, तो वह प्रतिक्रिया भेजता है। लंबे मतदान और अन्य तकनीकें काफी अच्छी तरह से काम करती हैं। हालांकि, ये सभी एक समस्या साझा करते हैं, वे HTTP के ओवरहेड को ले जाते हैं, जो उन्हें कम विलंबता अनुप्रयोगों के लिए अच्छी तरह से अनुकूल नहीं बनाता है। उदाहरण के लिए, ब्राउज़र में मल्टीप्लेयर शूटर गेम या रीयल-टाइम घटक के साथ कोई अन्य ऑनलाइन गेम।
वेब पर सॉकेट लाना
वेब सॉकेट विनिर्देश वेब ब्राउज़र और सर्वर के बीच "सॉकेट" कनेक्शन स्थापित करने वाले एक एपीआई को परिभाषित करता है। आम शब्दों में, क्लाइंट और सर्वर के बीच लगातार संबंध होता है और दोनों पक्ष किसी भी समय डेटा भेजना शुरू कर सकते हैं।
वेब सॉकेट कनेक्शन को बस एक कंस्ट्रक्टर का उपयोग करके खोला जा सकता है -
var connection = new WebSocket('ws://html5rocks.websocket.org/echo', ['soap', 'xmpp']);
wsWebSocket कनेक्शन के लिए नया URL स्कीमा है। वहाँ भीwss, सुरक्षित WebSocket कनेक्शन के लिए उसी तरह https का उपयोग सुरक्षित HTTP कनेक्शन के लिए किया जाता है।
कुछ ईवेंट हैंडलर को तुरंत कनेक्शन में संलग्न करना आपको यह जानने की अनुमति देता है कि कनेक्शन कब खोला गया है, आने वाले संदेशों को प्राप्त किया गया है, या कोई त्रुटि है।
दूसरा तर्क वैकल्पिक स्वीकार करता है subprotocols। यह एक स्ट्रिंग या स्ट्रिंग की एक सरणी हो सकती है। प्रत्येक स्ट्रिंग को एक का प्रतिनिधित्व करना चाहिएsubprotocol नाम और सर्वर पारित में से केवल एक को स्वीकार करता है subprotocolsसरणी में। स्वीकार किए जाते हैंsubprotocol WebSocket ऑब्जेक्ट की प्रोटोकॉल प्रॉपर्टी को एक्सेस करके निर्धारित किया जा सकता है।
// When the connection is open, send some data to the server
connection.onopen = function () {
connection.send('Ping'); // Send the message 'Ping' to the server
};
// Log errors
connection.onerror = function (error) {
console.log('WebSocket Error ' + error);
};
// Log messages from the server
connection.onmessage = function (e) {
console.log('Server: ' + e.data);
};
सर्वर के साथ संचार
जैसे ही हमारे पास सर्वर से कनेक्शन होता है (जब खुली घटना को निकाल दिया जाता है) हम कनेक्शन ऑब्जेक्ट पर सेंड (आपका संदेश) विधि का उपयोग करके सर्वर को डेटा भेजना शुरू कर सकते हैं। यह केवल तार का समर्थन करता था, लेकिन नवीनतम विनिर्देश में, यह अब बाइनरी संदेश भी भेज सकता है। बाइनरी डेटा भेजने के लिए, बूँद या एरेबफ़र ऑब्जेक्ट का उपयोग किया जाता है।
// Sending String
connection.send('your message');
// Sending canvas ImageData as ArrayBuffer
var img = canvas_context.getImageData(0, 0, 400, 320);
var binary = new Uint8Array(img.data.length);
for (var i = 0; i < img.data.length; i++) {
binary[i] = img.data[i];
}
connection.send(binary.buffer);
// Sending file as Blob
var file = document.querySelector('input[type = "file"]').files[0];
connection.send(file);
समान रूप से, सर्वर हमें किसी भी समय संदेश भेज सकता है। जब भी ऐसा होता है ऑनमेसेज कॉलबैक फायर हो जाता है। कॉलबैक से एक ईवेंट ऑब्जेक्ट प्राप्त होता है और वास्तविक संदेश data
प्रॉपर्टी के माध्यम से पहुंच योग्य होता है ।
WebSocket नवीनतम कल्पना में बाइनरी संदेश भी प्राप्त कर सकता है। बाइनरी फ्रेम को ब्लॉब या एरियरबफर प्रारूप में प्राप्त किया जा सकता है। प्राप्त बाइनरी के प्रारूप को निर्दिष्ट करने के लिए, WebSocket ऑब्जेक्ट के बाइनरी टाइप प्रॉपर्टी को 'बूँद' या 'सरणीबफ़र' पर सेट करें। डिफ़ॉल्ट प्रारूप 'बूँद' है।
// Setting binaryType to accept received binary as either 'blob' or 'arraybuffer'
connection.binaryType = 'arraybuffer';
connection.onmessage = function(e) {
console.log(e.data.byteLength); // ArrayBuffer object if binary
};
WebSocket का एक और नया जोड़ा फीचर एक्सटेंशन है। एक्सटेंशन का उपयोग करके, फ़्रेम को संपीड़ित, मल्टीप्लेक्स, आदि भेजना संभव होगा।
// Determining accepted extensions
console.log(connection.extensions);
क्रॉस-ऑरिजिन कम्युनिकेशन
एक आधुनिक प्रोटोकॉल होने के नाते, क्रॉस-ऑरिजिन संचार को वेबस्केट में सही बेक किया जाता है। WebSocket किसी भी डोमेन पर पार्टियों के बीच संचार को सक्षम बनाता है। सर्वर यह तय करता है कि उसकी सेवा सभी ग्राहकों के लिए उपलब्ध है या केवल उन लोगों के लिए जो अच्छी तरह से परिभाषित डोमेन के एक सेट पर रहते हैं।
प्रॉक्सी सर्वर
हर नई तकनीक समस्याओं के एक नए सेट के साथ आती है। WebSocket के मामले में यह प्रॉक्सी सर्वर के साथ अनुकूलता है, जो अधिकांश कंपनी नेटवर्क में HTTP कनेक्शनों की मध्यस्थता करता है। WebSocket प्रोटोकॉल HTTP अपग्रेड सिस्टम का उपयोग करता है (जो सामान्यतः HTTP / SSL के लिए उपयोग किया जाता है) एक Webboard सॉकेट से HTTP कनेक्शन को "अपग्रेड" करने के लिए। कुछ प्रॉक्सी सर्वर इसे पसंद नहीं करते हैं और कनेक्शन को छोड़ देंगे। इस प्रकार, यहां तक कि अगर एक दिया गया क्लाइंट वेबसोकेट प्रोटोकॉल का उपयोग करता है, तो कनेक्शन स्थापित करना संभव नहीं हो सकता है। यह अगले खंड को और भी महत्वपूर्ण बनाता है :)
सर्वर साइड
WebSocket का उपयोग करना सर्वर साइड एप्लिकेशन के लिए एक नया उपयोग पैटर्न बनाता है। जबकि LAMP जैसे पारंपरिक सर्वर स्टैक HTTP अनुरोध / प्रतिक्रिया चक्र के आसपास डिज़ाइन किए गए हैं, वे अक्सर बड़ी संख्या में खुले WebSocket कनेक्शन के साथ अच्छी तरह से व्यवहार नहीं करते हैं। एक ही समय में बड़ी संख्या में कनेक्शन खुले रखने के लिए एक आर्किटेक्चर की आवश्यकता होती है जो कम प्रदर्शन लागत पर उच्च संगामिति प्राप्त करता है।
प्रोटोकॉल को सुरक्षा कारणों से डिजाइन किया जाना चाहिए। WebSocket एक नया प्रोटोकॉल है और सभी वेब ब्राउज़र इसे सही तरीके से लागू नहीं करते हैं। उदाहरण के लिए, उनमें से कुछ अभी भी HTTP और WS के मिश्रण की अनुमति देते हैं, हालांकि विनिर्देश इसके विपरीत है। इस अध्याय में, हम कुछ सामान्य सुरक्षा हमलों पर चर्चा करेंगे, जिनके बारे में एक उपयोगकर्ता को पता होना चाहिए।
सेवा की मनाई
सेवा से इनकार (DoS) एक मशीन या नेटवर्क संसाधन को उपयोगकर्ताओं के लिए अनुपलब्ध बनाने का प्रयास करता है जो इसे अनुरोध करते हैं। मान लीजिए कि कोई व्यक्ति वेब सर्वर के लिए अनंत या बिना किसी समय अंतराल के कई अनुरोध करता है। सर्वर प्रत्येक कनेक्शन को संभालने में सक्षम नहीं है और या तो जवाब देना बंद कर देगा या बहुत धीरे-धीरे जवाब देना जारी रखेगा। इसे सेवा हमले से इनकार किया जा सकता है।
सेवा से इनकार करना अंतिम उपयोगकर्ताओं के लिए बहुत निराशाजनक है, जो वेब पेज लोड भी नहीं कर सकते थे।
DoS अटैक पीयर-टू-पीयर संचार पर भी लागू हो सकता है, जिससे पी 2 पी नेटवर्क के क्लाइंट पीड़ित वेब सर्वर से समवर्ती रूप से जुड़ सकते हैं।
बीच वाला व्यक्ति
इसे एक उदाहरण की मदद से समझते हैं।
मान लीजिए एक व्यक्ति A अपने दोस्त के साथ बातचीत कर रहा है BIM क्लाइंट के माध्यम से। कोई तीसरा व्यक्ति आपके द्वारा बदले गए संदेशों को देखना चाहता है। इसलिए, वह दोनों व्यक्तियों के साथ एक स्वतंत्र संबंध बनाता है। वह व्यक्ति को संदेश भी भेजता हैA और उसका दोस्त B, अपने संचार के लिए एक अदृश्य मध्यवर्ती के रूप में। इसे एक मध्यम आक्रमण के रूप में जाना जाता है।
मानव-में-मध्य प्रकार का हमला अनएन्क्रिप्टेड कनेक्शन के लिए आसान है, क्योंकि घुसपैठिया सीधे संकुल को पढ़ सकता है। जब कनेक्शन एन्क्रिप्ट किया जाता है, तो सूचना को हमलावर द्वारा डिक्रिप्ट किया जाना चाहिए, जो कि बहुत मुश्किल हो सकता है।
एक तकनीकी पहलू से, हमलावर एक सार्वजनिक-कुंजी संदेश विनिमय को स्वीकार करता है और अपने स्वयं के साथ अनुरोधित कुंजी को प्रतिस्थापित करते हुए संदेश भेजता है। जाहिर है, हमलावर की नौकरी को कठिन बनाने के लिए एक ठोस रणनीति एसएसएच का उपयोग वेबसॉकेट के साथ करना है।
ज्यादातर जब महत्वपूर्ण डेटा का आदान-प्रदान होता है, तो अनएन्क्रिप्टेड डब्ल्यूएस के बजाय डब्ल्यूएसएस सुरक्षित कनेक्शन पसंद करते हैं।
XSS
क्रॉस-साइट स्क्रिप्टिंग (XSS) एक भेद्यता है जो हमलावरों को क्लाइंट-साइड स्क्रिप्ट को वेब पेज या एप्लिकेशन में इंजेक्ट करने में सक्षम बनाती है। एक हमलावर आपके एप्लिकेशन हब का उपयोग करके HTML या जावास्क्रिप्ट कोड भेज सकता है और ग्राहकों की मशीनों पर इस कोड को निष्पादित किया जा सकता है।
WebSocket मूल रक्षा तंत्र
डिफ़ॉल्ट रूप से, WebSocket प्रोटोकॉल सुरक्षित होने के लिए डिज़ाइन किया गया है। वास्तविक दुनिया में, उपयोगकर्ता विभिन्न मुद्दों का सामना कर सकता है जो खराब ब्राउज़र कार्यान्वयन के कारण हो सकते हैं। जैसे ही समय बीतता है, ब्राउज़र विक्रेता किसी भी मुद्दे को तुरंत ठीक कर देते हैं।
SSH (या TLS) पर सुरक्षित WebSocket कनेक्शन का उपयोग करने पर सुरक्षा की एक अतिरिक्त परत जोड़ी जाती है।
WebSocket दुनिया में, मुख्य चिंता एक सुरक्षित कनेक्शन के प्रदर्शन के बारे में है। यद्यपि शीर्ष पर अभी भी एक अतिरिक्त टीएलएस परत है, प्रोटोकॉल में इस तरह के उपयोग के लिए अनुकूलन शामिल हैं, इसके अलावा, डब्ल्यूएसएस प्रॉक्सिज़ के माध्यम से अधिक चिकनाई से काम करता है।
क्लाइंट-टू-सर्वर मास्किंग
WebSocket सर्वर और WebSocket क्लाइंट के बीच प्रेषित हर संदेश में एक विशिष्ट कुंजी होती है, जिसका नाम मास्किंग कुंजी होता है, जो किसी भी WebSocket-compliant मध्यस्थ को संदेश को अनमस्क करने और निरीक्षण करने की अनुमति देता है। यदि मध्यस्थ WebSocket-compliant नहीं है, तो संदेश प्रभावित नहीं हो सकता है। WebSocket प्रोटोकॉल को लागू करने वाला ब्राउज़र मास्किंग को हैंडल करता है।
सुरक्षा टूलबॉक्स
अंत में, उपयोगी उपकरण आपके WebSocket क्लाइंट और सर्वर के बीच सूचना के प्रवाह की जांच करने, एक्सचेंज किए गए डेटा का विश्लेषण करने और संभावित जोखिमों की पहचान करने के लिए प्रस्तुत किए जा सकते हैं।
ब्राउज़र डेवलपर उपकरण
डेवलपर समर्थन के संदर्भ में क्रोम, फ़ायरफ़ॉक्स और ओपेरा महान ब्राउज़र हैं। उनके अंतर्निहित उपकरण हमें क्लाइंट-साइड इंटरैक्शन और संसाधनों के लगभग किसी भी पहलू को निर्धारित करने में मदद करते हैं। यह सुरक्षा उद्देश्यों के लिए एक महान भूमिका निभाता है।
WebSocket, जैसा कि नाम से ही स्पष्ट है, कुछ ऐसा है जो वेब का उपयोग करता है। वेब आमतौर पर ब्राउज़र पृष्ठों के साथ इंटरव्यू होता है क्योंकि वे ऑनलाइन डेटा प्रदर्शित करने के प्राथमिक साधन हैं। हालांकि, गैर-ब्राउज़र प्रोग्राम भी, ऑनलाइन डेटा ट्रांसमिशन का उपयोग करते हैं।
IPhone की रिलीज़ (शुरू में) और iPad (बाद में) ने वेब ब्राउज़र का उपयोग किए बिना आवश्यक रूप से वेब इंटरकनेक्टिविटी की एक नई दुनिया शुरू की। इसके बजाय, नए स्मार्टफोन और टैबलेट उपकरणों ने एक अद्वितीय उपयोगकर्ता अनुभव प्रदान करने के लिए देशी ऐप्स की शक्ति का उपयोग किया।
मोबाइल मैटर्स क्यों?
वर्तमान में, वहाँ एक अरब सक्रिय स्मार्टफोन हैं। यही है, आपके अनुप्रयोगों के लिए लाखों संभावित ग्राहक। ये लोग अपने मोबाइल फोन का उपयोग दैनिक कार्यों को पूरा करने के लिए करते हैं, इंटरनेट पर सर्फ करते हैं, संवाद करते हैं, या दुकान करते हैं।
स्मार्टफोन ऐप्स का पर्याय बन गए हैं। आजकल, किसी भी उपयोग के लिए एक ऐप है, एक उपयोगकर्ता सोच सकता है। डेटा पुनः प्राप्त करने, लेन-देन करने, समाचार एकत्र करने आदि के लिए अधिकांश ऐप इंटरनेट से जुड़ जाते हैं।
यह मौजूदा WebSocket ज्ञान का उपयोग करने और एक स्मार्टफोन या टैबलेट डिवाइस पर मूल रूप से चलने वाले WebSocket क्लाइंट को विकसित करने के लिए बहुत अच्छा होगा।
नेटिव मोबाइल ऐप बनाम मोबाइल वेबसाइट
खैर, यह एक आम संघर्ष है और हमेशा की तरह, उत्तर लक्षित दर्शकों की जरूरतों पर निर्भर करता है। यदि कोई उपयोगकर्ता आधुनिक डिजाइन रुझानों से परिचित है, तो एक वेबसाइट डिजाइन करना जो उत्तरदायी है और मोबाइल के अनुकूल है, अब एक आवश्यक है। हालांकि, अंतिम उपयोगकर्ता को यह सुनिश्चित करना चाहिए कि सामग्री, जो वास्तव में मायने रखती है, स्मार्टफोन के माध्यम से समान रूप से सुलभ है, क्योंकि यह एक क्लासिक डेस्कटॉप ब्राउज़र के माध्यम से है।
निश्चित रूप से, एक WebSocket वेब ऐप किसी भी HTML5-अनुरूप ब्राउज़र पर चलेगा, जिसमें मोबाइल ब्राउज़र जैसे कि iOS के लिए सफारी और मोबाइल पर Chrome शामिल हैं। इसलिए, स्मार्टफोन के साथ संगतता के मुद्दों के बारे में कोई चिंता नहीं है।
आवश्यक शर्तें
स्मार्टफोन ऐप विकसित करने के लिए, विकास उपकरण और एसडीके की स्थापना आवश्यक है।
कनेक्टेड मोबाइल और टैबलेट ग्राहकों के बीच संदेश प्रसारित करने के लिए WebSockets एक सार्वभौमिक हब के रूप में कार्य कर सकता है। हम एक देशी iOS एप्लिकेशन को कार्यान्वित कर सकते हैं, जो HTML5 जावास्क्रिप्ट क्लाइंट की तरह ही एक WebSocket सर्वर के साथ संचार करता है।