WebSockets - सुरक्षा
प्रोटोकॉल को सुरक्षा कारणों से डिजाइन किया जाना चाहिए। 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 क्लाइंट और सर्वर के बीच सूचना के प्रवाह की जांच, एक्सचेंज किए गए डेटा का विश्लेषण और संभावित जोखिमों की पहचान करने के लिए प्रस्तुत किए जा सकते हैं।
ब्राउज़र डेवलपर उपकरण
डेवलपर समर्थन के संदर्भ में क्रोम, फ़ायरफ़ॉक्स और ओपेरा महान ब्राउज़र हैं। उनके अंतर्निहित उपकरण हमें क्लाइंट-साइड इंटरैक्शन और संसाधनों के लगभग किसी भी पहलू को निर्धारित करने में मदद करते हैं। यह सुरक्षा उद्देश्यों के लिए एक महान भूमिका निभाता है।