वेब सेवाएँ - सुरक्षा
सुरक्षा वेब सेवाओं के लिए महत्वपूर्ण है। हालांकि, न तो XML-RPC और न ही SOAP विनिर्देश किसी भी स्पष्ट सुरक्षा या प्रमाणीकरण आवश्यकताओं को बनाते हैं।
वेब सेवाओं के साथ तीन विशिष्ट सुरक्षा मुद्दे हैं -
- Confidentiality
- Authentication
- नेटवर्क सुरक्षा
गोपनीयता
यदि कोई क्लाइंट किसी सर्वर पर XML अनुरोध भेजता है, तो क्या हम यह सुनिश्चित कर सकते हैं कि संचार गोपनीय रहे?
उत्तर यहाँ है -
- XML-RPC और SOAP मुख्य रूप से HTTP के ऊपर चलते हैं।
- HTTP में सिक्योर सॉकेट्स लेयर (SSL) के लिए सपोर्ट है।
- एसएसएल के माध्यम से संचार को एन्क्रिप्ट किया जा सकता है।
- एसएसएल एक सिद्ध तकनीक है और व्यापक रूप से तैनात है।
एक एकल वेब सेवा में अनुप्रयोगों की एक श्रृंखला शामिल हो सकती है। उदाहरण के लिए, एक बड़ी सेवा तीन अन्य अनुप्रयोगों की सेवाओं को एक साथ जोड़ सकती है। इस मामले में, एसएसएल पर्याप्त नहीं है; संदेश को सेवा पथ के साथ प्रत्येक नोड पर एन्क्रिप्ट किया जाना चाहिए, और प्रत्येक नोड श्रृंखला में एक संभावित कमजोर लिंक का प्रतिनिधित्व करता है। वर्तमान में, इस मुद्दे पर कोई सहमत-समाधान नहीं है, लेकिन एक आशाजनक समाधान W3C XML एन्क्रिप्शन मानक है। यह मानक पूरे XML दस्तावेज़ों को एन्क्रिप्ट करने या डिक्रिप्ट करने या XML दस्तावेज़ के कुछ हिस्सों के लिए एक रूपरेखा प्रदान करता है। आप इसे www.w3.org/Enc एन्क्रिप्शन पर देख सकते हैं
प्रमाणीकरण
यदि कोई ग्राहक किसी वेब सेवा से जुड़ता है, तो हम उपयोगकर्ता की पहचान कैसे करते हैं? क्या उपयोगकर्ता सेवा का उपयोग करने के लिए अधिकृत है?
निम्नलिखित विकल्पों पर विचार किया जा सकता है लेकिन एक मजबूत प्रमाणीकरण योजना पर कोई स्पष्ट सहमति नहीं है।
HTTP में बेसिक और डाइजेस्ट ऑथेंटिकेशन के लिए बिल्ट-इन सपोर्ट शामिल है और इसलिए सेवाओं को उसी तरह से संरक्षित किया जा सकता है जिस तरह से HTML डॉक्युमेंट्स को फिलहाल प्रोटेक्ट किया जाता है।
SOAP डिजिटल हस्ताक्षर (SOAP-DSIG) सार्वजनिक कुंजी क्रिप्टोग्राफी का लाभ लेने के लिए SOAP संदेशों पर हस्ताक्षर करता है। यह क्लाइंट या सर्वर को दूसरे पक्ष की पहचान को मान्य करने में सक्षम बनाता है। इसे www.w3.org/TR/SOAP-dsig पर देखें ।
संरचित सूचना मानकों (OASIS) की उन्नति के लिए संगठन सुरक्षा अभिकथन मार्कअप लैंग्वेज (SAML) पर काम कर रहा है।
नेटवर्क सुरक्षा
वर्तमान में इस समस्या का कोई आसान जवाब नहीं है, और यह बहुत बहस का विषय रहा है। अभी के लिए, यदि आप वास्तव में SOAP या XML-RPC संदेशों को फ़िल्टर करने के इरादे से हैं, तो एक संभावना उन सभी HTTP POST अनुरोधों को फ़िल्टर करने की है जो उनके सामग्री प्रकार को टेक्स्ट / xml पर सेट करते हैं।
एक अन्य विकल्प SOAPAction HTTP हेडर विशेषता को फ़िल्टर करना है। फ़ायरवॉल विक्रेता वर्तमान में वेब सेवा ट्रैफ़िक को फ़िल्टर करने के लिए स्पष्ट रूप से डिज़ाइन किए गए टूल विकसित कर रहे हैं।