वेब सेवाएँ - त्वरित गाइड
विभिन्न पुस्तकें और विभिन्न संगठन वेब सेवाओं के लिए विभिन्न परिभाषाएँ प्रदान करते हैं। उनमें से कुछ यहाँ सूचीबद्ध हैं।
एक वेब सेवा किसी भी सॉफ्टवेयर का एक टुकड़ा है जो खुद को इंटरनेट पर उपलब्ध कराता है और एक मानकीकृत XML संदेश प्रणाली का उपयोग करता है। XML का उपयोग सभी संचार को एक वेब सेवा को एन्कोड करने के लिए किया जाता है। उदाहरण के लिए, एक ग्राहक एक XML संदेश भेजकर एक वेब सेवा शुरू करता है, फिर इसी XML प्रतिक्रिया की प्रतीक्षा करता है। जैसा कि सभी संचार एक्सएमएल में है, वेब सेवाओं को किसी एक ऑपरेटिंग सिस्टम या प्रोग्रामिंग भाषा से नहीं जोड़ा जाता है - जावा पर्ल के साथ बात कर सकता है; विंडोज एप्लिकेशन यूनिक्स अनुप्रयोगों के साथ बात कर सकते हैं।
वेब सेवाएं स्व-निहित, मॉड्यूलर, वितरित, गतिशील अनुप्रयोग हैं जिन्हें उत्पादों, प्रक्रियाओं और आपूर्ति श्रृंखलाओं को बनाने के लिए नेटवर्क पर वर्णित, प्रकाशित, स्थित, या इनवोक किया जा सकता है। ये अनुप्रयोग स्थानीय, वितरित या वेब-आधारित हो सकते हैं। वेब सेवाओं को टीसीपी / आईपी, एचटीटीपी, जावा, एचटीएमएल और एक्सएमएल जैसे खुले मानकों के शीर्ष पर बनाया गया है।
वेब सेवाएं एक्सएमएल-आधारित सूचना विनिमय प्रणाली हैं जो इंटरनेट का उपयोग प्रत्यक्ष एप्लिकेशन-टू-एप्लिकेशन इंटरैक्शन के लिए करती हैं। इन प्रणालियों में प्रोग्राम, ऑब्जेक्ट, संदेश या दस्तावेज़ शामिल हो सकते हैं।
एक वेब सेवा खुले प्रोटोकॉल और मानकों का एक संग्रह है जिसका उपयोग अनुप्रयोगों या प्रणालियों के बीच डेटा के आदान-प्रदान के लिए किया जाता है। विभिन्न प्रोग्रामिंग भाषाओं में लिखे गए सॉफ़्टवेयर एप्लिकेशन और विभिन्न प्लेटफ़ॉर्म पर चल रहे कंप्यूटर एक ही कंप्यूटर पर अंतर-प्रक्रिया संचार के समान इंटरनेट जैसे कंप्यूटर नेटवर्क पर डेटा का आदान-प्रदान करने के लिए वेब सेवाओं का उपयोग कर सकते हैं। यह इंटरऑपरेबिलिटी (उदाहरण के लिए, जावा और पायथन या विंडोज और लिनक्स अनुप्रयोगों के बीच) खुले मानकों के उपयोग के कारण है।
संक्षेप में, एक पूर्ण वेब सेवा है, इसलिए, कोई भी सेवा -
इंटरनेट या निजी (इंट्रानेट) नेटवर्क पर उपलब्ध है
एक मानकीकृत XML संदेश प्रणाली का उपयोग करता है
किसी एक ऑपरेटिंग सिस्टम या प्रोग्रामिंग भाषा से बंधा नहीं है
एक सामान्य XML व्याकरण के माध्यम से स्व-वर्णन है
एक सरल खोज तंत्र के माध्यम से खोज योग्य है
वेब सेवाओं के घटक
मूल वेब सेवा मंच XML + HTTP है। सभी मानक वेब सेवाएँ निम्नलिखित घटकों का उपयोग कर काम करती हैं -
SOAP (सिंपल ऑब्जेक्ट एक्सेस प्रोटोकॉल)
UDDI (यूनिवर्सल विवरण, डिस्कवरी और एकीकरण)
WSDL (वेब सेवाएँ विवरण भाषा)
इन सभी घटकों की चर्चा वेब सर्विसेज आर्किटेक्चर चैप्टर में की गई है।
एक वेब सेवा कैसे काम करती है?
एक वेब सेवा HTML, XML, WSDL और SOAP जैसे खुले मानकों का उपयोग करके विभिन्न अनुप्रयोगों के बीच संचार को सक्षम करती है। एक वेब सेवा की मदद लेता है -
XML डेटा टैग करने के लिए
किसी संदेश को स्थानांतरित करने के लिए SOAP
डब्ल्यूएसडीएल सेवा की उपलब्धता का वर्णन करने के लिए।
आप सोलारिस पर एक जावा-आधारित वेब सेवा का निर्माण कर सकते हैं जो विंडोज पर चलने वाले आपके विज़ुअल बेसिक प्रोग्राम से सुलभ है।
आप Windows पर नई वेब सेवाओं के निर्माण के लिए C # का भी उपयोग कर सकते हैं जो आपके वेब एप्लिकेशन से मंगाई जा सकती हैं जो JavaServer Pages (JSP) पर आधारित है और Linux पर चलता है।
उदाहरण
एक सरल खाता-प्रबंधन और ऑर्डर प्रोसेसिंग सिस्टम पर विचार करें। लेखा कर्मी नए खाते बनाने और नए ग्राहक आदेश दर्ज करने के लिए विज़ुअल बेसिक या जेएसपी के साथ निर्मित क्लाइंट एप्लिकेशन का उपयोग करते हैं।
इस प्रणाली के लिए प्रसंस्करण तर्क जावा में लिखा गया है और सोलारिस मशीन पर रहता है, जो जानकारी संग्रहीत करने के लिए एक डेटाबेस के साथ बातचीत भी करता है।
इस ऑपरेशन को करने के लिए कदम इस प्रकार हैं -
क्लाइंट प्रोग्राम खाता पंजीकरण जानकारी को SOAP संदेश में बंडल करता है।
यह SOAP संदेश वेब सेवा को HTTP POST अनुरोध के मुख्य भाग के रूप में भेजा जाता है।
वेब सेवा SOAP अनुरोध को अनपैक करती है और इसे एक कमांड में परिवर्तित करती है जिसे एप्लिकेशन समझ सकता है।
आवेदन आवश्यक जानकारी को संसाधित करता है और उस ग्राहक के लिए एक नए अद्वितीय खाता संख्या के साथ प्रतिक्रिया करता है।
इसके बाद, वेब सेवा दूसरे SOAP संदेश में प्रतिक्रिया को पैकेज करती है, जिसे वह अपने HTTP अनुरोध के जवाब में क्लाइंट प्रोग्राम को वापस भेजती है।
क्लाइंट प्रोग्राम खाता पंजीकरण प्रक्रिया के परिणाम प्राप्त करने के लिए SOAP संदेश अनपैक करता है।
वेब सेवाओं के उपयोग के लाभ इस प्रकार हैं -
नेटवर्क पर मौजूदा फ़ंक्शन को उजागर करना
एक वेब सेवा प्रबंधित कोड की एक इकाई है जिसे HTTP का उपयोग करके दूरस्थ रूप से लागू किया जा सकता है। यही है, इसे HTTP अनुरोधों का उपयोग करके सक्रिय किया जा सकता है। वेब सेवाएं आपको नेटवर्क पर अपने मौजूदा कोड की कार्यक्षमता को उजागर करने की अनुमति देती हैं। एक बार जब यह नेटवर्क पर उजागर हो जाता है, तो अन्य एप्लिकेशन आपके प्रोग्राम की कार्यक्षमता का उपयोग कर सकते हैं।
इंटरोऑपरेबिलिटी
वेब सेवाएं विभिन्न अनुप्रयोगों को एक-दूसरे से बात करने और आपस में डेटा और सेवाओं को साझा करने की अनुमति देती हैं। अन्य एप्लिकेशन भी वेब सेवाओं का उपयोग कर सकते हैं। उदाहरण के लिए, एक VB या .NET एप्लिकेशन जावा वेब सेवाओं और इसके विपरीत से बात कर सकता है। वेब सेवाओं का उपयोग एप्लिकेशन प्लेटफॉर्म और प्रौद्योगिकी को स्वतंत्र बनाने के लिए किया जाता है।
मानकीकृत प्रोटोकॉल
वेब सेवाएं संचार के लिए मानकीकृत उद्योग मानक प्रोटोकॉल का उपयोग करती हैं। सभी चार लेयर्स (सर्विस ट्रांसपोर्ट, XML मैसेजिंग, सर्विस डिस्क्रिप्शन, और सर्विस डिस्कवरी लेयर्स) वेब प्रोटोकॉल प्रोटोकॉल स्टैक में अच्छी तरह से परिभाषित प्रोटोकॉल का उपयोग करते हैं। प्रोटोकॉल स्टैक का यह मानकीकरण व्यवसाय को कई लाभ प्रदान करता है जैसे कि विकल्पों की एक विस्तृत श्रृंखला, प्रतिस्पर्धा के कारण लागत में कमी, और गुणवत्ता में वृद्धि।
कम लागत का संचार
वेब सेवाएं HTTP प्रोटोकॉल पर SOAP का उपयोग करती हैं, इसलिए आप वेब सेवाओं को लागू करने के लिए अपने मौजूदा कम लागत वाले इंटरनेट का उपयोग कर सकते हैं। यह समाधान ईडीआई / बी 2 बी जैसे मालिकाना समाधानों की तुलना में बहुत कम महंगा है। HTTP पर SOAP के अलावा, वेब सेवाओं को FTP जैसे अन्य विश्वसनीय परिवहन तंत्रों पर भी लागू किया जा सकता है।
वेब सेवाओं में निम्नलिखित विशेष व्यवहार विशेषताएँ हैं -
एक्सएमएल आधारित
वेब सेवाएं डेटा प्रतिनिधित्व और डेटा परिवहन परतों पर XML का उपयोग करती हैं। XML का उपयोग किसी भी नेटवर्किंग, ऑपरेटिंग सिस्टम या प्लेटफ़ॉर्म बाइंडिंग को समाप्त कर देता है। वेब सेवाएं आधारित अनुप्रयोग अपने मूल स्तर पर अत्यधिक अंतर हैं।
आजादी से मिलना
किसी वेब सेवा का उपभोक्ता सीधे उस वेब सेवा से जुड़ा नहीं होता है। वेब सेवा इंटरफ़ेस ग्राहक के साथ सेवा के साथ बातचीत करने की क्षमता से समझौता किए बिना समय के साथ बदल सकता है। एक कसकर युग्मित प्रणाली का तात्पर्य है कि क्लाइंट और सर्वर लॉजिक एक दूसरे के साथ निकटता से जुड़े हुए हैं, जिसका अर्थ है कि यदि एक इंटरफ़ेस बदलता है, तो दूसरे को अपडेट किया जाना चाहिए। एक शिथिल युग्मित वास्तुकला को अपनाने से सॉफ्टवेयर सिस्टम अधिक प्रबंधनीय हो जाता है और विभिन्न प्रणालियों के बीच सरल एकीकरण की अनुमति मिलती है।
भोंडा
जावा जैसी वस्तु-उन्मुख प्रौद्योगिकियां व्यक्तिगत तरीकों के माध्यम से अपनी सेवाओं को उजागर करती हैं। एक व्यक्तिगत विधि एक कॉर्पोरेट स्तर पर किसी भी उपयोगी क्षमता प्रदान करने के लिए एक ऑपरेशन भी ठीक है। स्क्रैच से जावा प्रोग्राम का निर्माण करने के लिए कई बारीक-बारीक तरीकों के निर्माण की आवश्यकता होती है, जो तब एक मोटे-अनाज वाली सेवा में तैयार किए जाते हैं, जिसे ग्राहक या किसी अन्य सेवा द्वारा खाया जाता है।
व्यवसाय और वे इंटरफेस जिन्हें वे उजागर करते हैं, मोटे-मोटे होने चाहिए। वेब सेवा प्रौद्योगिकी मोटे अनाज वाली सेवाओं को परिभाषित करने का एक स्वाभाविक तरीका प्रदान करती है जो व्यवसाय तर्क की सही मात्रा तक पहुंच बनाती है।
सिंक्रोनस या एसिंक्रोनस होने की क्षमता
सिंक्रोनसिटी सेवा के निष्पादन के लिए क्लाइंट के बंधन को संदर्भित करता है। सिंक्रोनस इनवोकेशन में, क्लाइंट ब्लॉक करता है और जारी रखने से पहले अपने ऑपरेशन को पूरा करने के लिए सेवा का इंतजार करता है। अतुल्यकालिक संचालन एक ग्राहक को एक सेवा को लागू करने और फिर अन्य कार्यों को निष्पादित करने की अनुमति देता है।
अतुल्यकालिक ग्राहक बाद में समय पर अपना परिणाम प्राप्त करते हैं, जबकि सेवा पूरा होने पर सिंक्रोनस ग्राहक अपना परिणाम प्राप्त करते हैं। अतुल्यकालिक क्षमता शिथिल युग्मित प्रणालियों को सक्षम करने में एक महत्वपूर्ण कारक है।
दूरस्थ प्रक्रिया कॉल (RPCs) का समर्थन करता है
वेब सेवाएं क्लाइंट को एक्सएमएल-आधारित प्रोटोकॉल का उपयोग करके दूरस्थ वस्तुओं पर प्रक्रियाओं, कार्यों और विधियों को लागू करने की अनुमति देती हैं। दूरस्थ प्रक्रिया इनपुट और आउटपुट पैरामीटर को उजागर करती है जो एक वेब सेवा का समर्थन करना चाहिए।
एंटरप्राइज JavaBeans (EJBs) और .NET अवयवों के माध्यम से घटक विकास पिछले कुछ वर्षों में तेजी से आर्किटेक्चर और उद्यम तैनाती का एक हिस्सा बन गया है। दोनों प्रौद्योगिकियों को विभिन्न आरपीसी तंत्रों के माध्यम से वितरित और सुलभ किया जाता है।
एक वेब सेवा एक पारंपरिक घटक के बराबर, या एक EJB या .NET घटक के आह्वान में आने वाले इनवोकेशन का अनुवाद करके, अपनी स्वयं की सेवाएं प्रदान करके RPC का समर्थन करती है।
दस्तावेज़ विनिमय का समर्थन करता है
एक्सएमएल के प्रमुख लाभों में से एक न केवल डेटा का प्रतिनिधित्व करने का सामान्य तरीका है, बल्कि जटिल दस्तावेज भी हैं। ये दस्तावेज़ वर्तमान पते का प्रतिनिधित्व करने के रूप में सरल हो सकते हैं, या वे एक संपूर्ण पुस्तक या रिक्वेस्ट फॉर कोटेशन (RFQ) का प्रतिनिधित्व करने के रूप में जटिल हो सकते हैं। वेब सेवाएं व्यावसायिक एकीकरण की सुविधा के लिए दस्तावेजों के पारदर्शी आदान-प्रदान का समर्थन करती हैं।
वेब सेवा वास्तुकला को देखने के दो तरीके हैं -
- पहले प्रत्येक वेब सेवा अभिनेता की व्यक्तिगत भूमिकाओं की जांच करना है।
- दूसरा उभरते वेब सेवा प्रोटोकॉल स्टैक की जांच करना है।
वेब सेवा भूमिकाएँ
वेब सेवा वास्तुकला में तीन प्रमुख भूमिकाएँ हैं -
सेवा प्रदाता
यह वेब सेवा का प्रदाता है। सेवा प्रदाता सेवा को लागू करता है और इसे इंटरनेट पर उपलब्ध कराता है।
सेवा निवेदक
यह वेब सेवा का कोई भी उपभोक्ता है। अनुरोधकर्ता नेटवर्क कनेक्शन खोलकर और XML अनुरोध भेजकर एक मौजूदा वेब सेवा का उपयोग करता है।
सेवा रजिस्ट्री
यह सेवाओं की एक तार्किक रूप से केंद्रीकृत निर्देशिका है। रजिस्ट्री एक केंद्रीय स्थान प्रदान करती है जहां डेवलपर्स नई सेवाओं को प्रकाशित कर सकते हैं या मौजूदा लोगों को ढूंढ सकते हैं। इसलिए यह कंपनियों और उनकी सेवाओं के लिए एक केंद्रीकृत समाशोधन गृह के रूप में कार्य करता है।
वेब सेवा प्रोटोकॉल स्टैक
वेब सेवा वास्तुकला को देखने के लिए एक दूसरा विकल्प उभरते वेब सेवा प्रोटोकॉल स्टैक की जांच करना है। स्टैक अभी भी विकसित हो रहा है, लेकिन वर्तमान में चार मुख्य परतें हैं।
सेवा परिवहन
यह परत अनुप्रयोगों के बीच संदेश परिवहन के लिए जिम्मेदार है। वर्तमान में, इस परत में हाइपर टेक्स्ट ट्रांसपोर्ट प्रोटोकॉल (HTTP), सिंपल मेल ट्रांसफर प्रोटोकॉल (SMTP), फाइल ट्रांसफर प्रोटोकॉल (FTP), और नए प्रोटोकॉल जैसे ब्लॉक एक्सटेंसिबल एक्सचेंज प्रोटोकॉल (BEEP) शामिल हैं।
XML मैसेजिंग
यह परत एक सामान्य XML प्रारूप में संदेशों को एन्कोड करने के लिए ज़िम्मेदार है ताकि संदेशों को या तो अंत में समझा जा सके। वर्तमान में, इस परत में XML-RPC और SOAP शामिल हैं।
सेवा विवरण
यह परत एक विशेष वेब सेवा के लिए सार्वजनिक इंटरफ़ेस का वर्णन करने के लिए जिम्मेदार है। वर्तमान में, सेवा विवरण वेब सेवा विवरण भाषा (WSDL) के माध्यम से नियंत्रित किया जाता है।
सेवा खोज
यह परत एक सामान्य रजिस्ट्री में सेवाओं को केंद्रीकृत करने और आसान प्रकाशन / कार्यक्षमता खोजने के लिए जिम्मेदार है। वर्तमान में, सेवा खोज को यूनिवर्सल विवरण, डिस्कवरी और इंटीग्रेशन (UDDI) के माध्यम से नियंत्रित किया जाता है।
जैसे-जैसे वेब सेवाएँ विकसित होंगी, अतिरिक्त परतें जोड़ी जा सकती हैं और प्रत्येक परत में अतिरिक्त तकनीकों को जोड़ा जा सकता है।
अगला अध्याय वेब सेवाओं के घटकों की व्याख्या करता है।
सेवा परिवहन के बारे में कुछ शब्द
वेब सेवा प्रोटोकॉल स्टैक का निचला भाग सेवा परिवहन है। यह परत वास्तव में दो कंप्यूटरों के बीच XML संदेशों के परिवहन के लिए जिम्मेदार है।
हाइपर टेक्स्ट ट्रांसफर प्रोटोकॉल (HTTP)
वर्तमान में, HTTP सेवा परिवहन के लिए सबसे लोकप्रिय विकल्प है। HTTP सरल, स्थिर और व्यापक रूप से तैनात है। इसके अलावा, अधिकांश फ़ायरवॉल HTTP ट्रैफ़िक की अनुमति देते हैं। यह XMLRPC या SOAP संदेशों को HTTP संदेशों के रूप में बहाने की अनुमति देता है। यदि आप दूरस्थ अनुप्रयोगों को एकीकृत करना चाहते हैं तो यह अच्छा है, लेकिन यह कई सुरक्षा चिंताओं को बढ़ाता है और कई सुरक्षा चिंताओं को बढ़ाता है।
ब्लॉक एक्स्टेंसिबल एक्सचेंज प्रोटोकॉल (BEEP)
यह HTTP का एक आशाजनक विकल्प है। BEEP एक नया इंटरनेट इंजीनियरिंग टास्क फोर्स (IETF) है जो नए प्रोटोकॉल के निर्माण के लिए है। बीईईपी को सीधे टीसीपी पर स्तरित किया जाता है और इसमें एक अंतर्निहित हैंडशेक प्रोटोकॉल, प्रमाणीकरण, सुरक्षा और त्रुटि हैंडलिंग सहित कई अंतर्निहित विशेषताएं शामिल हैं। बीईईपी का उपयोग करके, व्यक्ति विभिन्न अनुप्रयोगों के लिए नए प्रोटोकॉल बना सकता है, जिसमें त्वरित संदेश, फ़ाइल स्थानांतरण, सामग्री सिंडिकेशन और नेटवर्क प्रबंधन शामिल हैं।
SOAP किसी विशिष्ट परिवहन प्रोटोकॉल से बंधा नहीं है। वास्तव में, आप HTTP, SMTP, या FTP के माध्यम से SOAP का उपयोग कर सकते हैं। एक आशाजनक विचार यह है कि बीईईपी पर SOAP का उपयोग किया जाए।
पिछले कुछ वर्षों में, तीन प्राथमिक प्रौद्योगिकियां दुनिया भर में मानकों के रूप में उभरी हैं जो आज की वेब सेवा प्रौद्योगिकी का मूल आधार बनाती हैं। इन तकनीकों पर नीचे चर्चा की गई है।
XML-RPC
कंप्यूटर के बीच सूचनाओं के आदान-प्रदान के लिए यह सबसे सरल XML- आधारित प्रोटोकॉल है।
XML-RPC एक साधारण प्रोटोकॉल है जो RPC करने के लिए XML संदेशों का उपयोग करता है।
अनुरोध XML में एन्कोड किए गए हैं और HTTP POST के माध्यम से भेजे गए हैं।
XML प्रतिक्रियाएं HTTP प्रतिक्रिया के शरीर में अंतर्निहित हैं।
XML-RPC प्लेटफ़ॉर्म-स्वतंत्र है।
एक्सएमएल-आरपीसी विविध अनुप्रयोगों को संवाद करने की अनुमति देता है।
एक जावा क्लाइंट एक पर्ल सर्वर से एक्सएमएल-आरपीसी बोल सकता है।
XML- RPC वेब सेवाओं के साथ आरंभ करने का सबसे आसान तरीका है।
XML-RPC के बारे में अधिक जानने के लिए, हमारे XML-RPC ट्यूटोरियल पर जाएँ ।
साबुन
SOAP कंप्यूटर के बीच सूचनाओं के आदान-प्रदान के लिए एक XML- आधारित प्रोटोकॉल है।
SOAP एक संचार प्रोटोकॉल है।
SOAP अनुप्रयोगों के बीच संचार के लिए है।
SOAP संदेश भेजने का एक प्रारूप है।
SOAP को इंटरनेट के माध्यम से संचार करने के लिए डिज़ाइन किया गया है।
SOAP प्लेटफ़ॉर्म स्वतंत्र है।
SOAP भाषा स्वतंत्र है।
एसओएपी सरल और एक्स्टेंसिबल है।
सोप आपको फायरवॉल के आसपास जाने की अनुमति देता है।
SOAP को W3C मानक के रूप में विकसित किया जाएगा।
SOAP के बारे में अधिक जानने के लिए, हमारे SOAP ट्यूटोरियल पर जाएँ ।
डबल्यूएसडीएल
WSDL वेब सेवाओं का वर्णन करने और उन्हें एक्सेस करने के लिए XML- आधारित भाषा है।
डब्लूएसडीएल वेब सेवाओं के विवरण भाषा के लिए है।
WSDL Microsoft और IBM द्वारा संयुक्त रूप से विकसित किया गया था।
डब्लूएसडीएल विकेंद्रीकृत और वितरित वातावरण में सूचना विनिमय के लिए एक्सएमएल आधारित प्रोटोकॉल है।
WSDL वेब सेवा का वर्णन करने के लिए मानक प्रारूप है।
डब्लूएसडीएल परिभाषा बताती है कि वेब सेवा का उपयोग कैसे किया जाता है और यह कौन से संचालन करेगा।
WSDL एक्सएमएल-आधारित सेवाओं के साथ इंटरफ़ेस करने के तरीके का वर्णन करने के लिए एक भाषा है।
डब्लूएसडीएल यूडीडीआई का एक अभिन्न अंग है, जो एक्सएमएल-आधारित दुनिया भर में व्यापार रजिस्ट्री है।
डब्लूएसडीएल वह भाषा है जिसका यूडीडीआई उपयोग करता है।
WSDL को 'wiz-dull' और 'WSD-L' के रूप में बताया जाता है।
WSDL के बारे में अधिक जानने के लिए, हमारे WSDL ट्यूटोरियल पर जाएँ ।
UDDI
UDDI वेब सेवाओं का वर्णन, प्रकाशन और खोजने के लिए एक XML- आधारित मानक है।
UDDI का अर्थ है यूनिवर्सल डिटेल, डिस्कवरी और इंटीग्रेशन।
UDDI वेब सेवाओं की वितरित रजिस्ट्री के लिए एक विनिर्देश है।
UDDI प्लेटफ़ॉर्म स्वतंत्र, खुली रूपरेखा है।
UDDI SOAP, CORBA और Java RMI प्रोटोकॉल के माध्यम से संवाद कर सकता है।
UDDI वेब सेवाओं के लिए इंटरफेस का वर्णन करने के लिए WSDL का उपयोग करता है।
UDDI को SOAP और WSDL के साथ वेब सेवाओं के तीन नींव मानकों में से एक के रूप में देखा जाता है।
UDDI एक खुली उद्योग पहल है जो व्यवसायों को एक-दूसरे की खोज करने और यह परिभाषित करने में सक्षम करती है कि वे इंटरनेट पर कैसे बातचीत करते हैं।
UDDI के बारे में अधिक जानने के लिए, हमारे UDDI ट्यूटोरियल पर जाएँ ।
वेब सेवा वास्तुकला के आधार पर, हम वेब सेवा कार्यान्वयन के एक भाग के रूप में निम्नलिखित दो घटक बनाते हैं -
सेवा प्रदाता या प्रकाशक
यह वेब सेवा का प्रदाता है। सेवा प्रदाता सेवा को लागू करता है और इसे इंटरनेट या इंट्रानेट पर उपलब्ध कराता है।
हम .NET SDK का उपयोग करके एक साधारण वेब सेवा लिखेंगे और प्रकाशित करेंगे।
सेवा अनुरोधकर्ता या उपभोक्ता
यह वेब सेवा का कोई भी उपभोक्ता है। अनुरोधकर्ता नेटवर्क कनेक्शन खोलकर और XML अनुरोध भेजकर एक मौजूदा वेब सेवा का उपयोग करता है।
हम दो वेब सेवा अनुरोध भी लिखेंगे: एक वेब-आधारित उपभोक्ता (ASP.NET अनुप्रयोग) और दूसरा Windows अनुप्रयोग-आधारित उपभोक्ता।
नीचे दिया गया हमारा पहला वेब सेवा उदाहरण है जो सेवा प्रदाता के रूप में काम करता है और अनुप्रयोगों द्वारा उपयोग की जाने वाली वेब सेवाओं के रूप में दो विधियों (जोड़ और SayHello) को उजागर करता है। यह वेब सेवा के लिए एक मानक टेम्पलेट है। .NET वेब सेवाएँ .asmx एक्सटेंशन का उपयोग करती हैं। ध्यान दें कि वेब सेवा के रूप में उजागर की गई विधि में WebMethod विशेषता है। इस फ़ाइल को IIS वर्चुअल निर्देशिका में FirstService.asmx के रूप में सहेजें (जैसा कि IIS को कॉन्फ़िगर करने में समझाया गया है; उदाहरण के लिए, c: \ MyWebSerces)।
FirstService.asmx
<%@ WebService language = "C#" class = "FirstService" %>
using System;
using System.Web.Services;
using System.Xml.Serialization;
[WebService(Namespace = "http://localhost/MyWebServices/")]
public class FirstService : WebService{
[WebMethod]
public int Add(int a, int b) {
return a + b;
}
[WebMethod]
public String SayHello() {
return "Hello World";
}
}
वेब सेवा का परीक्षण करने के लिए, इसे प्रकाशित किया जाना चाहिए। एक वेब सेवा को इंट्रानेट या इंटरनेट पर प्रकाशित किया जा सकता है। हम इस वेब सेवा को स्थानीय मशीन पर चलने वाले IIS पर प्रकाशित करेंगे। आइए हम IIS को कॉन्फ़िगर करने के साथ शुरू करते हैं।
ओपन स्टार्ट → सेटिंग्स → कंट्रोल पैनल → प्रशासनिक उपकरण → इंटरनेट सेवा प्रबंधक।
डिफ़ॉल्ट वेब साइट पर विस्तार और राइट-क्लिक करें; नया & # rarr चुनें; आभासी निर्देशिका। वर्चुअल डायरेक्टरी क्रिएशन विजार्ड खुलता है। अगला पर क्लिक करें।
"वर्चुअल डायरेक्टरी एलियास" स्क्रीन खुलती है। वर्चुअल निर्देशिका नाम टाइप करें। उदाहरण के लिए, MyWebServices। अगला पर क्लिक करें।
"वेब साइट सामग्री निर्देशिका" स्क्रीन खुलती है।
वर्चुअल निर्देशिका के लिए निर्देशिका पथ नाम दर्ज करें। उदाहरण के लिए, c: \ MyWebServices। अगला पर क्लिक करें।
"एक्सेस परमिशन" स्क्रीन खुलती है। अपनी आवश्यकताओं के अनुसार सेटिंग्स बदलें। आइए हम इस अभ्यास के लिए डिफ़ॉल्ट सेटिंग्स रखें।
नेक्स्ट बटन पर क्लिक करें। यह IIS कॉन्फ़िगरेशन को पूरा करता है।
कॉन्फ़िगरेशन पूरा करने के लिए समाप्त पर क्लिक करें।
यह जांचने के लिए कि क्या IIS ठीक से कॉन्फ़िगर किया गया है, ऊपर बनाई गई वर्चुअल निर्देशिका (C: \ MyWebServices) में HTML फ़ाइल (उदाहरण के लिए, x.html) की प्रतिलिपि बनाएँ। अब, इंटरनेट एक्सप्लोरर खोलें और टाइप करेंhttp://localhost/MyWebServices/x.html। इसे x.html फ़ाइल को खोलना चाहिए।
Note- अगर यह काम नहीं करता है, तो अपनी मशीन के आईपी पते के साथ लोकलहोस्ट को बदलने का प्रयास करें। यदि यह अभी भी काम नहीं करता है, तो जांचें कि क्या IIS चल रहा है; आपको IIS और वर्चुअल निर्देशिका को पुन: कॉन्फ़िगर करने की आवश्यकता हो सकती है।
इस वेब सेवा का परीक्षण करने के लिए, ऊपर बनाई गई IIS वर्चुअल निर्देशिका में FirstService.asmx को कॉपी करें (C: \ MyWebServices)। Internet Explorer (http: //localhost/MyWebServices/FirstService.asmx) में वेब सेवा खोलें। उसे अपना वेब सेवा पृष्ठ खोलना चाहिए। पृष्ठ में हमारे अनुप्रयोग द्वारा वेब सेवाओं के रूप में उजागर दो विधियों के लिंक होने चाहिए। बधाई हो! आपने अपनी पहली वेब सेवा लिखी है!
वेब सेवा का परीक्षण
जैसा कि हमने अभी देखा है, .NET फ्रेमवर्क में वेब सेवाओं को लिखना आसान है। वेब सेवा उपभोक्ताओं को लिखना भी .NET फ्रेमवर्क में आसान है; हालाँकि, यह थोड़ा अधिक शामिल है। जैसा कि पहले कहा गया था, हम दो प्रकार के सेवा उपभोक्ताओं को लिखेंगे, एक वेब-आधारित और दूसरा विंडोज़ अनुप्रयोग-आधारित उपभोक्ता। हमें अपना पहला वेब सेवा उपभोक्ता लिखना है।
वेब-आधारित सेवा उपभोक्ता
नीचे दिए गए अनुसार वेब-आधारित उपभोक्ता लिखें। इसे WebApp.aspx कहें। ध्यान दें कि यह एक ASP.NET अनुप्रयोग है। इसे वेब सेवा (c: \ MyWebServices \ WebApp.axpx) की आभासी निर्देशिका में सहेजें।
इस एप्लिकेशन में दो टेक्स्ट फ़ील्ड हैं जिनका उपयोग उपयोगकर्ता से नंबर जोड़ने के लिए किया जाता है। इसमें एक बटन होता है, Execute, जिसे क्लिक करने पर Add और SayHello वेब सेवाएं मिलती हैं।
WebApp.aspx
<%@ Page Language = "C#" %>
<script runat = "server">
void runSrvice_Click(Object sender, EventArgs e) {
FirstService mySvc = new FirstService();
Label1.Text = mySvc.SayHello();
Label2.Text = mySvc.Add(Int32.Parse(txtNum1.Text), Int32.Parse(txtNum2.Text)).ToString();
}
</script>
<html>
<head> </head>
<body>
<form runat = "server">
<p>
<em>First Number to Add </em>:
<asp:TextBox id = "txtNum1" runat = "server" Width = "43px">4< /asp:TextBox>
</p>
<p>
<em>Second Number To Add </em>:
<asp:TextBox id = "txtNum2" runat = "server" Width = "44px">5</asp:TextBox>
</p>
<p>
<strong><u>Web Service Result -</u></strong>
</p>
<p>
<em>Hello world Service</em> :
<asp:Label id = "Label1" runat = "server" Font-Underline = "True">Label< /asp:Label>
</p>
<p>
<em>Add Service</em> :
& <asp:Label id = "Label2" runat = "server" Font-Underline = "True">Label</asp:Label>
</p>
<p align = "left">
<asp:Button id = "runSrvice" onclick = "runSrvice_Click" runat = "server" Text = "Execute"></asp:Button>
</p>
</form>
</body>
</html>
उपभोक्ता बनने के बाद, हमें वेब सेवा का उपभोग करने के लिए एक प्रॉक्सी बनाने की आवश्यकता है। यह कार्य हमारे लिए विजुअल स्टूडियो .NET द्वारा स्वचालित रूप से किया जाता है जब एक वेब सेवा को जोड़ा जाता है। यहां दिए गए चरणों का पालन किया जा रहा है -
वेब सेवा का उपभोग करने के लिए एक प्रॉक्सी बनाएं। प्रॉक्सी को .NET SDK के साथ आपूर्ति की गई WSDL उपयोगिता का उपयोग करके बनाया गया है। यह उपयोगिता वेब सेवा से जानकारी निकालती है और एक प्रॉक्सी बनाती है। प्रॉक्सी केवल एक विशेष वेब सेवा के लिए मान्य है। यदि आपको अन्य वेब सेवाओं का उपभोग करने की आवश्यकता है, तो आपको इस सेवा के लिए एक प्रॉक्सी बनाने की आवश्यकता है। जब वेब सेवा संदर्भ जोड़ा जाता है, तो Visual Studio .NET आपके लिए स्वचालित रूप से एक प्रॉक्सी बनाता है। .NET SDK के साथ आपूर्ति की गई WSDL उपयोगिता का उपयोग करके वेब सेवा के लिए एक प्रॉक्सी बनाएं। यह वर्तमान निर्देशिका में FirstSevice.cs फ़ाइल बनाएगा। हमें वेब सेवा के लिए FirstService.dll (प्रॉक्सी) बनाने के लिए इसे संकलित करने की आवश्यकता है।
c:> WSDL http://localhost/MyWebServices/FirstService.asmx?WSDL
c:> csc /t:library FirstService.cs
संकलित प्रॉक्सी को वेब सेवा (c: \ MyWebServices \ bin) की वर्चुअल निर्देशिका की बिन निर्देशिका में रखें। इंटरनेट सूचना सेवा (IIS) इस निर्देशिका में प्रॉक्सी की तलाश करती है।
सेवा उपभोक्ता बनाएं, उसी तरह जैसे हमने पहले ही किया था। ध्यान दें कि वेब सेवा प्रॉक्सी की एक वस्तु उपभोक्ता में त्वरित है। यह प्रॉक्सी सेवा के साथ बातचीत करने का ध्यान रखती है।
IE में उपभोक्ता का URL टाइप करें ताकि वह इसका परीक्षण कर सके (उदाहरण के लिए, http: //localhost/MyWebServices/WebApp.aspx)।
Windows अनुप्रयोग-आधारित वेब सेवा उपभोक्ता
Windows अनुप्रयोग-आधारित वेब सेवा उपभोक्ता लिखना किसी भी अन्य Windows अनुप्रयोग को लिखने के समान है। आपको केवल प्रॉक्सी (जो हम पहले ही कर चुके हैं) बनाने की जरूरत है और आवेदन को संकलित करते समय इस प्रॉक्सी का संदर्भ लें। वेब सेवा का उपयोग करने वाला हमारा विंडोज एप्लिकेशन निम्नलिखित है। यह एप्लिकेशन एक वेब सेवा ऑब्जेक्ट बनाता है (बेशक, प्रॉक्सी) और SayHello को कॉल करता है, और इस पर तरीके जोड़ें।
WinApp.cs
using System;
using System.IO;
namespace SvcConsumer {
class SvcEater {
public static void Main(String[] args) {
FirstService mySvc = new FirstService();
Console.WriteLine("Calling Hello World Service: " + mySvc.SayHello());
Console.WriteLine("Calling Add(2, 3) Service: " + mySvc.Add(2, 3).ToString());
}
}
}
इसका उपयोग करके संकलन करें c:\>csc /r:FirstService.dll WinApp.cs
। यह WinApp.exe बनाएगा। एप्लिकेशन और वेब सेवा का परीक्षण करने के लिए इसे चलाएं।
अब, सवाल उठता है: आप यह कैसे सुनिश्चित कर सकते हैं कि यह एप्लिकेशन वास्तव में वेब सेवा कह रहा है?
यह परीक्षण करने के लिए सरल है। अपने वेब सर्वर को बंद करें ताकि वेब सेवा से संपर्क न किया जा सके। अब, WinApp एप्लिकेशन चलाएं। यह एक रनटाइम अपवाद को आग देगा। अब, वेब सर्वर को फिर से शुरू करें। यह काम करना चाहिए।
सुरक्षा वेब सेवाओं के लिए महत्वपूर्ण है। हालांकि, न तो एक्सएमएल-आरपीसी और न ही एसओएपी विनिर्देश किसी भी स्पष्ट सुरक्षा या प्रमाणीकरण आवश्यकताओं को बनाते हैं।
वेब सेवाओं के साथ तीन विशिष्ट सुरक्षा मुद्दे हैं -
- 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 हेडर विशेषता को फ़िल्टर करना है। फ़ायरवॉल विक्रेता वर्तमान में वेब सेवा ट्रैफ़िक को फ़िल्टर करने के लिए स्पष्ट रूप से डिज़ाइन किए गए टूल विकसित कर रहे हैं।
यह अध्याय आपको वेब सेवाओं से संबंधित सभी नवीनतम मानकों का विचार देता है।
परिवहन
बीईईपी, ब्लॉक एक्सटेंसिबल एक्सचेंज प्रोटोकॉल (जिसे पूर्व में बीएक्सपीपी कहा जाता है), एप्लिकेशन प्रोटोकॉल के निर्माण के लिए एक रूपरेखा है। यह IETF द्वारा मानकीकृत किया गया है और यह इंटरनेट प्रोटोकॉल के लिए करता है कि XML ने डेटा के लिए क्या किया है।
ब्लॉक एक्स्टेंसिबल एक्सचेंज प्रोटोकॉल (BEEP)
संदेश
इन संदेशन मानकों और विशिष्टताओं का उद्देश्य विकेंद्रीकृत, वितरित पर्यावरण में सूचनाओं के आदान-प्रदान के लिए एक रूपरेखा प्रदान करना है।
सोप 1.1 (नोट)
SOAP 1.2 (विशिष्टता)
वेब सेवा संलग्नक प्रोफाइल 1.0
SOAP संदेश संचरण अनुकूलन तंत्र
विवरण और खोज
वेब सेवाएं तभी सार्थक होती हैं जब संभावित उपयोगकर्ता अपने निष्पादन की अनुमति देने के लिए पर्याप्त जानकारी पा सकते हैं। इन विशिष्टताओं और मानकों का ध्यान व्यवसायों, संगठनों और अन्य वेब सेवा प्रदाताओं के विवरण और खोज का समर्थन करने वाली सेवाओं के एक सेट की परिभाषा है; वे उपलब्ध कराने वाली वेब सेवाएं; और तकनीकी इंटरफेस जिसका उपयोग उन सेवाओं तक पहुंचने के लिए किया जा सकता है।
UDDI 3.0
WSDL 1.1 (नोट)
WSDL 1.2 (कार्य प्रारूप)
डब्लूएसडीएल २.० (वर्किंग ग्रुप)
सुरक्षा
इन सुरक्षा विशिष्टताओं का उपयोग करते हुए, एप्लिकेशन सामान्य वेब सेवा ढांचे के साथ काम करने के लिए डिज़ाइन किए गए सुरक्षित संचार में संलग्न हो सकते हैं।
वेब सेवा सुरक्षा 1.0
सुरक्षा अभिकथन मार्कअप लैंग्वेज (SAML)
प्रबंध
वेब सेवाओं की संरचना, उपलब्धता, स्वास्थ्य, प्रदर्शन, उपयोग के साथ-साथ वेब सेवाओं के आर्किटेक्चर के भीतर वेब सेवा के नियंत्रण और कॉन्फ़िगरेशन की खोज के लिए क्षमताओं का एक समूह के रूप में परिभाषित किया गया है। जैसे-जैसे वेब सेवाएं व्यवसायिक कार्यों के लिए व्यापक और महत्वपूर्ण होती जाती हैं, उन्हें प्रबंधित करने और कार्यान्वित करने का कार्य व्यवसाय संचालन की सफलता के लिए आवश्यक है।
वेब सेवाएँ वितरित प्रबंधन
इस ट्यूटोरियल में, आपने सीखा कि वेब सेवाओं का उपयोग कैसे करें। हालाँकि, एक वेब सेवा में WSDL, UDDI और SOAP जैसे घटक शामिल हैं जो इसे सक्रिय बनाने में योगदान करते हैं। अगला कदम WSDL, UDDI और SOAP सीखना है।
डबल्यूएसडीएल
WSDL वेब सेवाओं का वर्णन करने और उन्हें एक्सेस करने के लिए XML- आधारित भाषा है।
WSDL वेब सेवा के लिए संदेश प्रारूप और प्रोटोकॉल विवरण के साथ एक वेब सेवा का वर्णन करता है।
WSDL के बारे में अधिक जानने के लिए, हमारे WSDL ट्यूटोरियल पर जाएँ ।
UDDI
UDDI वेब सेवाओं का वर्णन, प्रकाशन और खोजने के लिए एक XML- आधारित मानक है।
UDDI के बारे में अधिक जानने के लिए, हमारे UDDI ट्यूटोरियल पर जाएँ ।
साबुन
SOAP एक सरल XML- आधारित प्रोटोकॉल है जो एप्लिकेशन को HTTP पर जानकारी का आदान-प्रदान करने की अनुमति देता है।
SOAP के बारे में अधिक जानने के लिए, हमारे SOAP ट्यूटोरियल पर जाएँ ।