SOAP - त्वरित गाइड
SOAP सिंपल ऑब्जेक्ट एक्सेस प्रोटोकॉल के लिए एक संक्षिप्त रूप है। यह कंप्यूटरों में सूचनाओं के आदान-प्रदान के लिए एक XML- आधारित मैसेजिंग प्रोटोकॉल है। SOAP XML विनिर्देशन का एक अनुप्रयोग है।
नोट करने के लिए अंक
SOAP एक संचार प्रोटोकॉल है जिसे इंटरनेट के माध्यम से संचार करने के लिए डिज़ाइन किया गया है।
SOAP XML संदेश के लिए HTTP का विस्तार कर सकता है।
SOAP वेब सेवाओं के लिए डेटा परिवहन प्रदान करता है।
SOAP पूर्ण दस्तावेजों का आदान-प्रदान कर सकता है या एक दूरस्थ प्रक्रिया कह सकता है।
किसी संदेश को प्रसारित करने के लिए SOAP का उपयोग किया जा सकता है।
SOAP प्लेटफॉर्म है- और भाषा-स्वतंत्र।
SOAP XML को परिभाषित करने का तरीका है कि क्या जानकारी भेजी जाती है और कैसे।
SOAP क्लाइंट एप्लिकेशन को दूरस्थ सेवाओं से आसानी से कनेक्ट करने और दूरस्थ विधियों को लागू करने में सक्षम बनाता है।
यद्यपि SOAP का उपयोग विभिन्न संदेश प्रणालियों में किया जा सकता है और विभिन्न प्रकार के परिवहन प्रोटोकॉल के माध्यम से वितरित किया जा सकता है, SOAP का प्रारंभिक ध्यान दूरस्थ प्रक्रिया कॉल HTTP के माध्यम से ले जाया जाता है।
CORBA, DCOM और Java RMI सहित अन्य चौखटे SOAP को समान कार्यक्षमता प्रदान करते हैं, लेकिन SOAP संदेश पूरी तरह से XML में लिखे गए हैं और इसलिए विशिष्ट रूप से प्लेटफॉर्म- और भाषा-स्वतंत्र हैं।
SOAP संदेश एक साधारण XML दस्तावेज़ है जिसमें निम्नलिखित तत्व हैं -
Envelope- संदेश की शुरुआत और अंत को परिभाषित करता है। यह एक अनिवार्य तत्व है।
Header- संदेश को संसाधित करने में उपयोग किए गए संदेश की किसी भी वैकल्पिक विशेषताओं को शामिल करता है, या तो एक मध्यस्थ बिंदु पर या अंतिम छोर पर। यह एक वैकल्पिक तत्व है।
Body- इसमें भेजे जा रहे संदेश में XML डेटा शामिल है। यह एक अनिवार्य तत्व है।
Fault - एक वैकल्पिक दोष तत्व जो संदेशों को संसाधित करते समय होने वाली त्रुटियों के बारे में जानकारी प्रदान करता है।
इन सभी तत्वों को SOAP लिफाफे के लिए डिफ़ॉल्ट नाम स्थान में घोषित किया गया है - http://www.w3.org/2001/12/soap-envelope और SOAP एन्कोडिंग और डेटा प्रकारों के लिए डिफ़ॉल्ट नामस्थान है - http://www.w3.org/2001/12/soap-encoding
NOTE- ये सभी विनिर्देश परिवर्तन के अधीन हैं। इसलिए W3 वेबसाइट पर उपलब्ध नवीनतम विनिर्देशों के साथ खुद को अपडेट रखें।
SOAP संदेश संरचना
निम्नलिखित ब्लॉक एक SOAP संदेश की सामान्य संरचना को दर्शाता है -
<?xml version = "1.0"?>
<SOAP-ENV:Envelope xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
SOAP-ENV:encodingStyle = "http://www.w3.org/2001/12/soap-encoding">
<SOAP-ENV:Header>
...
...
</SOAP-ENV:Header>
<SOAP-ENV:Body>
...
...
<SOAP-ENV:Fault>
...
...
</SOAP-ENV:Fault>
...
</SOAP-ENV:Body>
</SOAP_ENV:Envelope>
SOAP लिफाफा संदेश के प्रारंभ और अंत को इंगित करता है ताकि रिसीवर जानता है कि जब एक संपूर्ण संदेश प्राप्त हुआ है। एसओएपी लिफाफा यह जानने की समस्या को हल करता है कि आपको कब संदेश प्राप्त किया जाता है और इसे संसाधित करने के लिए तैयार हैं। इसलिए SOAP लिफाफा मूल रूप से एक पैकेजिंग तंत्र है।
नोट करने के लिए अंक
प्रत्येक SOAP संदेश में एक मूल लिफाफा तत्व होता है।
लिफाफा SOAP संदेश का अनिवार्य हिस्सा है।
प्रत्येक लिफ़ाफ़े तत्व में ठीक एक बॉडी तत्व होना चाहिए।
यदि एक लिफाफे में एक हेडर तत्व होता है, तो उसमें एक से अधिक नहीं होना चाहिए, और यह शरीर के पहले लिफाफे के पहले बच्चे के रूप में दिखाई देना चाहिए।
लिफाफा बदल जाता है जब SOAP संस्करण बदल जाते हैं।
SOV लिफाफा ENV नाम स्थान उपसर्ग और लिफाफा तत्व का उपयोग करके निर्दिष्ट किया गया है।
वैकल्पिक सोप एन्कोडिंग भी एक नाम स्थान नाम और वैकल्पिक का उपयोग कर निर्दिष्ट किया जाता है encodingStyle तत्व है, जो भी साबुन से अलग किसी एन्कोडिंग शैली को इंगित कर सकते हैं।
V1.1 लिफ़ाफ़ा नामस्थान वाले संदेश को प्राप्त करने पर एक v1.1-आज्ञाकारी SOAP प्रोसेसर एक गलती उत्पन्न करता है।
यदि v1.2 लिफ़ाफ़ा नामस्थान शामिल नहीं है, तो यह एक संदेश प्राप्त करता है जो एक v1.2- संगत सोप प्रोसेसर एक वर्जनस्मैच गलती उत्पन्न करता है।
v1.2-शिकायत SOAP संदेश
नीचे दिया गया एक उदाहरण है v1.2-आज्ञाकारी SOAP संदेश।
<?xml version = "1.0"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
SOAP-ENV:encodingStyle = " http://www.w3.org/2001/12/soap-encoding">
...
Message information goes here
...
</SOAP-ENV:Envelope>
HTTP POST के साथ SOAP
निम्न उदाहरण HTTP POST ऑपरेशन के भीतर SOAP संदेश के उपयोग को दिखाता है, जो सर्वर को संदेश भेजता है। यह लिफाफा स्कीमा परिभाषा और एन्कोडिंग नियमों की स्कीमा परिभाषा के लिए नामस्थान दिखाता है। OrderEntry HTTP शीर्ष लेख में संदर्भ प्रोग्राम का नाम tutorialspoint.com वेबसाइट पर लागू किया जा रहा है।
POST /OrderEntry HTTP/1.1
Host: www.tutorialspoint.com
Content-Type: application/soap; charset = "utf-8"
Content-Length: nnnn
<?xml version = "1.0"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
SOAP-ENV:encodingStyle = " http://www.w3.org/2001/12/soap-encoding">
...
Message information goes here
...
</SOAP-ENV:Envelope>
NOTE - HTTP बाइंडिंग सेवा का स्थान निर्दिष्ट करता है।
वैकल्पिक हैडर तत्व अतिरिक्त एप्लिकेशन-स्तरीय आवश्यकताओं को निर्दिष्ट करने के लिए एक लचीली रूपरेखा प्रदान करता है। उदाहरण के लिए, पासवर्ड-सुरक्षित सेवाओं के लिए डिजिटल हस्ताक्षर निर्दिष्ट करने के लिए हेडर तत्व का उपयोग किया जा सकता है। इसी तरह, इसका उपयोग भुगतान-प्रति-उपयोग SOAP सेवाओं के लिए खाता संख्या निर्दिष्ट करने के लिए किया जा सकता है।
नोट करने के लिए अंक
यह SOAP संदेश का एक वैकल्पिक हिस्सा है।
हैडर तत्व कई बार हो सकते हैं।
हेडर का उद्देश्य नई सुविधाओं और कार्यक्षमता को जोड़ना है।
SOAP हेडर में एक नेमस्पेस में परिभाषित हेडर एंट्रीज होती हैं।
शीर्षलेख को SOAP लिफाफे के पहले तत्काल बाल तत्व के रूप में एन्कोड किया गया है।
जब कई हेडर परिभाषित होते हैं, तो SOAP हेडर के सभी तात्कालिक बाल तत्वों की व्याख्या SOAP हेडर ब्लॉक के रूप में की जाती है।
सोप हैडर विशेषताएँ
SOAP हैडर में निम्नलिखित दो विशेषताएँ हो सकती हैं -
अभिनेता की विशेषता
SOAP प्रोटोकॉल संदेश पथ को SOAP सेवा नोड्स की सूची के रूप में परिभाषित करता है। इनमें से प्रत्येक मध्यवर्ती नोड्स कुछ प्रसंस्करण कर सकते हैं और फिर श्रृंखला में अगले नोड को संदेश अग्रेषित कर सकते हैं। अभिनेता विशेषता सेट करके, ग्राहक SOAP हेडर के प्राप्तकर्ता को निर्दिष्ट कर सकता है।
MustUnderstand विशेषता
यह इंगित करता है कि हैडर तत्व वैकल्पिक है या अनिवार्य। यदि सही पर सेट किया जाता है, तो प्राप्तकर्ता को उसके परिभाषित शब्दार्थ के अनुसार हेडर विशेषता को समझना और संसाधित करना होगा, या एक गलती वापस करना होगा।
निम्न उदाहरण दिखाता है कि SOAP संदेश में एक हेडर का उपयोग कैसे करें।
<?xml version = "1.0"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = " http://www.w3.org/2001/12/soap-envelope"
SOAP-ENV:encodingStyle = " http://www.w3.org/2001/12/soap-encoding">
<SOAP-ENV:Header>
<t:Transaction
xmlns:t = "http://www.tutorialspoint.com/transaction/"
SOAP-ENV:mustUnderstand = "true">5
</t:Transaction>
</SOAP-ENV:Header>
...
...
</SOAP-ENV:Envelope>
SOAP निकाय एक अनिवार्य तत्व है जिसमें SOAP संदेश में अनुप्रयोग-परिभाषित XML डेटा का आदान-प्रदान होता है। शरीर को लिफाफे के भीतर होना चाहिए और संदेश के लिए परिभाषित किए जाने वाले किसी भी शीर्षलेख का पालन करना चाहिए।
शरीर को लिफाफे के एक बाल तत्व के रूप में परिभाषित किया गया है, और शरीर के शब्दार्थ को संबंधित SOAP स्कीमा में परिभाषित किया गया है।
संदेश के अंतिम प्राप्तकर्ता के लिए शरीर में अनिवार्य जानकारी होती है। उदाहरण के लिए -
<?xml version = "1.0"?>
<SOAP-ENV:Envelope>
........
<SOAP-ENV:Body>
<m:GetQuotation xmlns:m = "http://www.tp.com/Quotation">
<m:Item>Computers</m:Item>
</m:GetQuotation>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
उपरोक्त उदाहरण कंप्यूटर सेट के एक उद्धरण का अनुरोध करता है। ध्यान दें कि m: GetQuotation और उपरोक्त आइटम तत्व अनुप्रयोग-विशिष्ट तत्व हैं। वे SOAP मानक का हिस्सा नहीं हैं।
यहाँ उपरोक्त क्वेरी की प्रतिक्रिया है -
<?xml version = "1.0"?>
<SOAP-ENV:Envelope>
........
<SOAP-ENV:Body>
<m:GetQuotationResponse xmlns:m = "http://www.tp.com/Quotation">
<m:Quotation>This is Qutation</m:Quotation>
</m:GetQuotationResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
आम तौर पर, आवेदन भी अनुरोध और प्रतिक्रिया तत्वों से जुड़े शब्दार्थ को सम्मिलित करने के लिए एक स्कीमा को परिभाषित करता है।
कोटेशन सेवा एक EJB एक आवेदन सर्वर में चल रहा का उपयोग कर लागू किया जा सकता है, यदि ऐसा है, तो SOAP प्रोसेसर GetQuotationResponse सेवा के EJB कार्यान्वयन में और बाहर मापदंडों के रूप में शरीर की जानकारी के मानचित्रण के लिए जिम्मेदार होगा । SOAP प्रोसेसर शरीर की जानकारी को एक .NET ऑब्जेक्ट, एक CORBA ऑब्जेक्ट, एक COBOL प्रोग्राम, और इसी तरह मैप कर सकता है।
यदि प्रक्रिया के दौरान कोई त्रुटि होती है, तो SOAP संदेश की प्रतिक्रिया संदेश के मुख्य भाग में SOAP गलती तत्व है, और गलती SOAP संदेश के प्रेषक को वापस कर दी जाती है।
SOAP गलती तंत्र त्रुटि के बारे में विशिष्ट जानकारी देता है, जिसमें एक पूर्वनिर्धारित कोड, एक विवरण और SOAP प्रोसेसर का पता शामिल होता है जो गलती उत्पन्न करता है।
नोट करने के लिए अंक
एक SOAP संदेश केवल एक गलती ब्लॉक ले जा सकता है।
दोष एक SOAP संदेश का एक वैकल्पिक हिस्सा है।
HTTP बाइंडिंग के लिए, एक सफल प्रतिक्रिया 200 से 299 श्रेणी के कोड से जुड़ी होती है।
सोप फॉल्ट 500 से 599 श्रेणी के स्टेटस कोड से जुड़ा हुआ है।
दोष के उप-तत्व
SOAP दोष के निम्नलिखित उप तत्व हैं -
अनु क्रमांक | उप-तत्व और विवरण |
---|---|
1 | <faultCode> यह एक पाठ कोड है जिसका उपयोग त्रुटियों की एक कक्षा को इंगित करने के लिए किया जाता है। पूर्वनिर्धारित गलती कोड की एक सूची के लिए अगली तालिका देखें। |
2 | <faultString> यह एक टेक्स्ट मैसेज है जो एरर को समझाता है। |
3 | <faultActor> यह एक पाठ स्ट्रिंग है जो यह दर्शाता है कि किसने गलती की। यह उपयोगी है अगर SOAP संदेश SOAP संदेश पथ में कई नोड्स के माध्यम से यात्रा करता है, और क्लाइंट को यह जानना होगा कि किस नोड में त्रुटि हुई। एक नोड जो अंतिम गंतव्य के रूप में कार्य नहीं करता है, उसमें एक गलती एलेक्टर तत्व शामिल होना चाहिए । |
4 | <detail> यह एप्लिकेशन-विशिष्ट त्रुटि संदेशों को ले जाने के लिए उपयोग किया जाने वाला एक तत्व है। डिटेल एलिमेंट में चाइल्ड एलिमेंट्स हो सकते हैं जिन्हें डिटेल एंट्रीज कहते हैं। |
सोप फॉल्ट कोड्स
दोषों का वर्णन करते समय फॉल्टकोड तत्वों में नीचे दिए गए फॉल्टकोड मान का उपयोग किया जाना चाहिए ।
अनु क्रमांक | त्रुटि विवरण |
---|---|
1 | SOAP-ENV:VersionMismatch SOAP लिफ़ाफ़े तत्व के लिए एक अमान्य नाम स्थान मिला। |
2 | SOAP-ENV:MustUnderstand हेडर तत्व का एक तात्कालिक बाल तत्व, "1" के लिए सेट किया गया mustUnderstand विशेषता के साथ, समझा नहीं गया था। |
3 | SOAP-ENV:Client संदेश गलत तरीके से बनाया गया था या उसमें गलत जानकारी थी। |
4 | SOAP-ENV:Server सर्वर में कोई समस्या थी, इसलिए संदेश आगे नहीं बढ़ सका। |
सोप दोष उदाहरण
निम्नलिखित कोड एक नमूना दोष है। क्लाइंट ने ValidateCreditCard नाम की एक विधि का अनुरोध किया है , लेकिन सेवा ऐसी विधि का समर्थन नहीं करती है। यह क्लाइंट अनुरोध त्रुटि का प्रतिनिधित्व करता है, और सर्वर निम्नलिखित SOAP प्रतिक्रिया देता है -
<?xml version = '1.0' encoding = 'UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi = "http://www.w3.org/1999/XMLSchema-instance"
xmlns:xsd = "http://www.w3.org/1999/XMLSchema">
<SOAP-ENV:Body>
<SOAP-ENV:Fault>
<faultcode xsi:type = "xsd:string">SOAP-ENV:Client</faultcode>
<faultstring xsi:type = "xsd:string">
Failed to locate method (ValidateCreditCard) in class (examplesCreditCard) at
/usr/local/ActivePerl-5.6/lib/site_perl/5.6.0/SOAP/Lite.pm line 1555.
</faultstring>
</SOAP-ENV:Fault>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
SOAP में डेटा प्रकार एन्कोडिंग के लिए नियमों का एक अंतर्निहित सेट शामिल है। यह SOAP संदेश को विशिष्ट डेटा प्रकार, जैसे पूर्णांक, फ़्लोट्स, डबल्स, या सरणियाँ इंगित करने के लिए सक्षम करता है।
SOAP डेटा प्रकारों को दो व्यापक श्रेणियों में विभाजित किया जाता है - स्केलर प्रकार और यौगिक प्रकार।
स्केलर प्रकारों में एक अंतिम नाम, मूल्य या उत्पाद विवरण जैसे बिल्कुल एक मूल्य होते हैं।
यौगिक प्रकारों में कई मूल्य होते हैं जैसे कि खरीद ऑर्डर या स्टॉक कोट्स की सूची।
यौगिक प्रकार आगे सरणियों और संरचनाओं में विभाजित हैं।
SOAP संदेश के लिए एन्कोडिंग शैली SOAP-ENV: एन्कोडिंग स्टाइल विशेषता के माध्यम से सेट की गई है ।
SOAP 1.1 एन्कोडिंग का उपयोग करने के लिए, मान का उपयोग करें http://schemas.xmlsoap.org/soap/encoding/
SOAP 1.2 एन्कोडिंग का उपयोग करने के लिए, मान का उपयोग करें http://www.w3.org/2001/12/soap-encoding
नवीनतम SOAP विनिर्देश XML स्कीमा द्वारा परिभाषित सभी अंतर्निहित प्रकारों को अपनाता है। फिर भी, एसओएपी एक्सएमएल स्कीमा द्वारा निर्दिष्ट नहीं किए गए निर्माणों को परिभाषित करने के लिए अपना स्वयं का सम्मेलन बनाए रखता है, जैसे कि सरणियां और संदर्भ।
स्केलर प्रकार
स्केलर प्रकारों के लिए, SOAP XML स्कीमा विनिर्देश द्वारा निर्दिष्ट सभी अंतर्निहित सरल प्रकारों को अपनाता है। इसमें स्ट्रिंग्स, फ्लोट्स, डबल्स और पूर्णांक शामिल हैं।
निम्न तालिका मुख्य योजनाओं को सूचीबद्ध करती है, एक्सएमएल स्कीमा भाग 0 - प्राइमर के कुछ अंश http://www.w3.org/TR/2000/WD-xmlschema-0-20000407/
एक्सएमएल स्कीमा में निर्मित सरल प्रकार | ||
---|---|---|
सरल प्रकार | उदाहरण) | |
तार | इस बात की पुष्टि इलेक्ट्रिक है। | |
बूलियन | सच्चा, झूठा, १, ०। | |
नाव | -INF, -1E4, -0, 0, 12.78E-2, 12, INF, NaN। | |
दोहरा | -INF, -1E4, -0, 0, 12.78E-2, 12, INF, NaN। | |
दशमलव | -1.23, 0, 123.4, 1000.00। | |
बायनरी | 100,010 | |
पूर्णांक | -126789, -1, 0, 1, 126789। | |
nonPositiveInteger | -126789, -1, 0। | |
negativeInteger | -126789, -1। | |
लंबा | -1, 12678967543233 | |
पूर्णांक | -1, 126789675 | |
कम | -1, 12678 | |
बाइट | -1, 126 | |
nonNegativeInteger | 0, 1, 126789 | |
unsignedLong | 0, 12678967543233 है | |
unsignedInt | 0, 1267896754 है | |
unsignedShort | 0, 12678 है | |
unsignedByte | 0, 126 | |
सकारात्मक पूर्णांक | 1, 126789। | |
दिनांक | 1999-05-31, --- 05। | |
समय | 13: 20: 00.000, 13: 20: 00.000-05: 00 |
उदाहरण के लिए, यहां दोहरे डेटा प्रकार के साथ SOAP प्रतिक्रिया है -
<?xml version = '1.0' encoding = 'UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd = "http://www.w3.org/2001/XMLSchema">
<SOAP-ENV:Body>
<ns1:getPriceResponse
xmlns:ns1 = "urn:examples:priceservice"
SOAP-ENV:encodingStyle = "http://www.w3.org/2001/12/soap-encoding">
<return xsi:type = "xsd:double">54.99</return>
</ns1:getPriceResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
यौगिक प्रकार
SOAP सरणियों में नियमों का एक बहुत विशिष्ट सेट होता है, जिसके लिए आवश्यक है कि आप तत्व प्रकार और सरणी आकार दोनों को निर्दिष्ट करें। SOAP भी बहुआयामी सरणियों का समर्थन करता है, लेकिन सभी SOAP कार्यान्वयन बहुआयामी कार्यक्षमता का समर्थन नहीं करते हैं।
एक सरणी बनाने के लिए, आपको इसे xsi: सरणी के प्रकार के रूप में निर्दिष्ट करना होगा । सरणी में एक सरणी टाइप विशेषता भी होनी चाहिए । यह विशेषता निहित तत्वों और सरणी के आयाम (ओं) के लिए डेटा प्रकार को निर्दिष्ट करने के लिए आवश्यक है।
उदाहरण के लिए, निम्नलिखित विशेषता 10 दोहरे मानों की एक सरणी निर्दिष्ट करती है -
arrayType = "xsd:double[10]"
इसके विपरीत, निम्नलिखित विशेषता तार के द्वि-आयामी सरणी को निर्दिष्ट करती है -
arrayType = "xsd:string[5,5]"
यहाँ दोहरे मूल्यों की एक सरणी के साथ एक नमूना SOAP प्रतिक्रिया है -
<?xml version = '1.0' encoding = 'UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd = "http://www.w3.org/2001/XMLSchema">
<SOAP-ENV:Body>
<ns1:getPriceListResponse
xmlns:ns1 = "urn:examples:pricelistservice"
SOAP-ENV:encodingStyle = "http://www.w3.org/2001/12/soap-encoding">
<return xmlns:ns2 = "http://www.w3.org/2001/09/soap-encoding"
xsi:type = "ns2:Array" ns2:arrayType = "xsd:double[2]">
<item xsi:type = "xsd:double">54.99</item>
<item xsi:type = "xsd:double">19.99</item>
</return>
</ns1:getPriceListResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
संरचनाओं में कई मूल्य होते हैं, लेकिन प्रत्येक तत्व एक अद्वितीय एक्सेसर तत्व के साथ निर्दिष्ट होता है। उदाहरण के लिए, किसी उत्पाद कैटलॉग में किसी आइटम पर विचार करें। इस स्थिति में, संरचना में उत्पाद SKU, उत्पाद का नाम, विवरण और मूल्य हो सकते हैं। यहां बताया गया है कि इस तरह के ढांचे को SOAP संदेश में कैसे दर्शाया जाएगा -
<?xml version = '1.0' encoding = 'UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd = "http://www.w3.org/2001/XMLSchema">
<SOAP-ENV:Body>
<ns1:getProductResponse
xmlns:ns1 = "urn:examples:productservice"
SOAP-ENV:encodingStyle = "http://www.w3.org/2001/12/soap-encoding">
<return xmlns:ns2 = "urn:examples" xsi:type = "ns2:product">
<name xsi:type = "xsd:string">Red Hat Linux</name>
<price xsi:type = "xsd:double">54.99</price>
<description xsi:type = "xsd:string">
Red Hat Linux Operating System
</description>
<SKU xsi:type = "xsd:string">A358185</SKU>
</return>
</ns1:getProductResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
NOTE- अपना SOAP कोड लिखते समय कृपया उचित इंडेंटेशन का ध्यान रखें। एक संरचना में प्रत्येक तत्व एक अद्वितीय एक्सेसर नाम के साथ निर्दिष्ट किया गया है। उदाहरण के लिए, ऊपर दिए गए संदेश में चार एक्सेसर तत्व शामिल हैं - नाम, मूल्य, विवरण और SKU। प्रत्येक तत्व का अपना डेटा प्रकार हो सकता है। उदाहरण के लिए, नाम एक स्ट्रिंग के रूप में निर्दिष्ट किया गया है, जबकि मूल्य डबल के रूप में निर्दिष्ट किया गया है।
SOAP किसी भी परिवहन प्रोटोकॉल से बंधा नहीं है। SOAP को SMTP, FTP, IBM के MQSeries या Microsoft संदेश कतार (MSMQ) के माध्यम से ले जाया जा सकता है।
SOAP विनिर्देश में केवल HTTP पर विवरण शामिल हैं। HTTP सबसे लोकप्रिय SOAP परिवहन प्रोटोकॉल है।
HTTP के माध्यम से SOAP
तार्किक रूप से, SOAP अनुरोधों को HTTP अनुरोध के माध्यम से भेजा जाता है और SOAP प्रतिक्रियाएं HTTP प्रतिक्रिया की सामग्री के भीतर वापस कर दी जाती हैं। जबकि SOAP अनुरोध HTTP GET के माध्यम से भेजे जा सकते हैं, विनिर्देश में केवल HTTP POST पर विवरण शामिल है।
इसके अतिरिक्त, HTTP अनुरोधों और प्रतिक्रियाओं दोनों को पाठ / xml पर अपनी सामग्री प्रकार सेट करने के लिए आवश्यक है।
SOAP विनिर्देश यह बताता है कि क्लाइंट को SOAPAction हेडर प्रदान करना चाहिए , लेकिन SOAPAction हेडर का वास्तविक मूल्य SOAP सर्वर कार्यान्वयन पर निर्भर है।
उदाहरण के लिए, एमाविस्टा बबेलफिश ट्रांसलेशन सेवा को एक्सेस करने के लिए, जिसे एक्समिथोड्स द्वारा होस्ट किया गया है, आपको SOAPAction हेडर के रूप में निम्नलिखित निर्दिष्ट करना होगा।
urn:xmethodsBabelFish#BabelFish
भले ही सर्वर को पूर्ण SOAPAction हेडर की आवश्यकता नहीं है, क्लाइंट को एक खाली स्ट्रिंग ("") या एक शून्य मान निर्दिष्ट करना होगा। उदाहरण के लिए -
SOAPAction: ""
SOAPAction:
यहाँ एक नमूना अनुरोध HTTP के माध्यम से XMethods Babelfish अनुवाद सेवा के लिए भेजा गया है -
POST /perl/soaplite.cgi HTTP/1.0
Host: services.xmethods.com
Content-Type: text/xml; charset = utf-8
Content-Length: 538
SOAPAction: "urn:xmethodsBabelFish#BabelFish"
<?xml version = '1.0' encoding = 'UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi = "http://www.w3.org/1999/XMLSchema-instance"
xmlns:xsd = "http://www.w3.org/1999/XMLSchema">
<SOAP-ENV:Body>
<ns1:BabelFish
xmlns:ns1 = "urn:xmethodsBabelFish"
SOAP-ENV:encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/">
<translationmode xsi:type = "xsd:string">en_fr</translationmode>
<sourcedata xsi:type = "xsd:string">Hello, world!</sourcedata>
</ns1:BabelFish>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
सामग्री प्रकार और SOAPAction शीर्षक पर ध्यान दें। यह भी ध्यान दें कि BabelFish विधि को दो स्ट्रिंग मापदंडों की आवश्यकता होती है। अनुवाद मोड en_fr अंग्रेजी से फ्रेंच में अनुवाद करता है।
यहाँ XMethods से प्रतिक्रिया है -
HTTP/1.1 200 OK
Date: Sat, 09 Jun 2001 15:01:55 GMT
Server: Apache/1.3.14 (Unix) tomcat/1.0 PHP/4.0.1pl2
SOAPServer: SOAP::Lite/Perl/0.50
Cache-Control: s-maxage = 60, proxy-revalidate
Content-Length: 539
Content-Type: text/xml
<?xml version = "1.0" encoding = "UTF-8"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENC = "http://schemas.xmlsoap.org/soap/encoding/"
SOAP-ENV:encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
xmlns:xsi = "http://www.w3.org/1999/XMLSchema-instance"
xmlns:SOAP-ENV = "http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsd = "http://www.w3.org/1999/XMLSchema">
<SOAP-ENV:Body>
<namesp1:BabelFishResponse xmlns:namesp1 = "urn:xmethodsBabelFish">
<return xsi:type = "xsd:string">Bonjour, monde!</return>
</namesp1:BabelFishResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
HTTP के माध्यम से वितरित SOAP प्रतिक्रियाओं को उसी HTTP स्थिति कोड का पालन करना आवश्यक है। उदाहरण के लिए, 200 ओके का एक स्थिति कोड एक सफल प्रतिक्रिया दर्शाता है। 500 आंतरिक सर्वर त्रुटि का एक स्थिति कोड बताता है कि सर्वर त्रुटि है और SOAP प्रतिक्रिया में एक दोष तत्व शामिल है।
नीचे दिए गए उदाहरण में, GetQuotation अनुरोध को HTTP पर SOAP सर्वर पर भेजा जाता है। अनुरोध में एक QuotationName पैरामीटर है, और एक उद्धरण प्रतिक्रिया में दिया जाएगा।
फ़ंक्शन के लिए नामस्थान में परिभाषित किया गया है http://www.xyz.org/quotation पता।
यहाँ SOAP अनुरोध है -
POST /Quotation HTTP/1.0
Host: www.xyz.org
Content-Type: text/xml; charset = utf-8
Content-Length: nnn
<?xml version = "1.0"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
SOAP-ENV:encodingStyle = "http://www.w3.org/2001/12/soap-encoding">
<SOAP-ENV:Body xmlns:m = "http://www.xyz.org/quotations">
<m:GetQuotation>
<m:QuotationsName>MiscroSoft</m:QuotationsName>
</m:GetQuotation>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
इसी SOAP प्रतिक्रिया की तरह दिखता है -
HTTP/1.0 200 OK
Content-Type: text/xml; charset = utf-8
Content-Length: nnn
<?xml version = "1.0"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV = "http://www.w3.org/2001/12/soap-envelope"
SOAP-ENV:encodingStyle = "http://www.w3.org/2001/12/soap-encoding">
<SOAP-ENV:Body xmlns:m = "http://www.xyz.org/quotation">
<m:GetQuotationResponse>
<m:Quotation>Here is the quotation</m:Quotation>
</m:GetQuotationResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
SOAP 1.1 को मूल रूप से मई 2000 में W3C को प्रस्तुत किया गया था। आधिकारिक सबमिटर में Microsoft, IBM, और Ariba जैसी बड़ी कंपनियाँ और UserLand Software और DevelopMentor जैसी छोटी कंपनियाँ शामिल थीं।
जुलाई 2001 में, XML प्रोटोकॉल वर्किंग ग्रुप ने SOAP 1.2 का "वर्किंग ड्राफ्ट" जारी किया। W3C के भीतर, यह दस्तावेज़ आधिकारिक तौर पर कार्य प्रगति पर है, जिसका अर्थ है कि दस्तावेज़ को अंतिम रूप दिए जाने से पहले कई बार अपडेट किए जाने की संभावना है।
सोप संस्करण 1.1 ऑनलाइन उपलब्ध है http://www.w3.org/TR/SOAP/
सोप वर्जन 1.2 का वर्किंग ड्राफ्ट यहां उपलब्ध है http://www.w3.org/TR/soap12/
ध्यान दें कि W3C "SOAP मैसेज विद अटैचमेंट्स" के लिए एक सबमिशन भी होस्ट करता है, जो कोर SOAP स्पेसिफिकेशन से अलग है। यह विनिर्देश छवियों और ध्वनि फ़ाइलों जैसे बाइनरी संलग्नक को शामिल करने के लिए SOAP संदेशों को सक्षम करता है। पूर्ण विवरण के लिए, W3C नोट को देखेंhttp://www.w3.org/TR/SOAP-attachments।