UDDI - त्वरित गाइड

UDDI वेब सेवाओं का वर्णन, प्रकाशन और खोजने के लिए एक XML- आधारित मानक है।

  • UDDI के लिए खड़ा है Universal Description, Discovery, and Integration.

  • UDDI वेब सेवाओं की वितरित रजिस्ट्री के लिए एक विनिर्देश है।

  • UDDI एक प्लेटफ़ॉर्म-इंडिपेंडेंट, ओपन फ्रेमवर्क है।

  • UDDI SOAP, CORBA, Java RMI प्रोटोकॉल के माध्यम से संवाद कर सकता है।

  • UDDI वेब सेवाओं के लिए इंटरफेस का वर्णन करने के लिए वेब सेवा परिभाषा भाषा (WSDL) का उपयोग करता है।

  • UDDI को SOAP और WSDL के साथ वेब सेवाओं के तीन नींव मानकों में से एक के रूप में देखा जाता है।

  • UDDI एक खुली उद्योग पहल है, जो व्यवसायों को एक-दूसरे की खोज करने और यह परिभाषित करने में सक्षम करती है कि वे इंटरनेट पर कैसे बातचीत करते हैं।

UDDI के दो खंड हैं -

  • सभी वेब सेवा के मेटाडेटा की एक रजिस्ट्री, जिसमें एक सेवा के WSDL विवरण के लिए एक सूचक भी शामिल है।

  • उस रजिस्ट्री में हेरफेर और खोज के लिए WSDL पोर्ट प्रकार परिभाषाओं का एक सेट।

UDDI का इतिहास

  • UDDI 1.0 की घोषणा मूल रूप से Microsoft, IBM और Ariba ने सितंबर 2000 में की थी।

  • प्रारंभिक घोषणा के बाद से, UDDI पहल ने डेल, फुजित्सु, एचपी, हिताची, आईबीएम, इंटेल, माइक्रोसॉफ्ट, ओरेकल, एसएपी और सन सहित 300 से अधिक कंपनियों को शामिल किया है।

  • मई 2001 में, Microsoft और IBM ने पहले UDDI ऑपरेटर साइटों को लॉन्च किया और UDDI रजिस्ट्री को लाइव किया।

  • जून 2001 में, UDDI ने संस्करण 2.0 की घोषणा की।

  • इस ट्यूटोरियल के लेखन के समय, Microsoft और IBM साइट्स ने 1.0 विनिर्देशन लागू किया था और निकट भविष्य में 2.0 समर्थन की योजना बना रहे थे।

  • वर्तमान में UDDI OASIS द्वारा प्रायोजित है।

साथी इंटरफ़ेस प्रक्रियाएँ

पार्टनर इंटरफेस प्रोसेस (पीआईपी) एक्सएमएल आधारित इंटरफेस हैं जो दो ट्रेडिंग भागीदारों को डेटा का आदान-प्रदान करने में सक्षम बनाते हैं। दर्जनों PIP पहले से मौजूद हैं। उनमें से कुछ यहाँ सूचीबद्ध हैं -

  • PIP2A2 - उत्पाद की जानकारी के लिए एक साथी को क्वेरी करने में सक्षम बनाता है।

  • PIP3A2 - विशिष्ट उत्पादों की कीमत और उपलब्धता की क्वेरी करने के लिए एक भागीदार को सक्षम करता है।

  • PIP3A4 - इलेक्ट्रॉनिक खरीद ऑर्डर सबमिट करने और ऑर्डर की पावती प्राप्त करने के लिए एक भागीदार को सक्षम करता है।

  • PIP3A3 - इलेक्ट्रॉनिक शॉपिंग कार्ट की सामग्री को स्थानांतरित करने के लिए एक भागीदार को सक्षम करता है।

  • PIP3B4 - एक विशिष्ट शिपमेंट की स्थिति को क्वेरी करने के लिए एक भागीदार को सक्षम करता है।

निजी UDDI रजिस्ट्रियां

इंटरनेट पर उपलब्ध UDDI रजिस्ट्रियों के सार्वजनिक फ़ेडरेटेड नेटवर्क का उपयोग करने के विकल्प के रूप में, कंपनियां या उद्योग समूह अपनी निजी UDDI रजिस्ट्रियों को लागू करने का विकल्प चुन सकते हैं।

इन विशेष सेवाओं को कंपनी या उद्योग समूह के सदस्यों को आपस में सेवाओं को साझा करने और विज्ञापित करने की अनुमति देने के उद्देश्य से बनाया गया है।

भले ही UDDI रजिस्ट्री वैश्विक फ़ेडरेटेड नेटवर्क का हिस्सा हो या निजी स्वामित्व वाली और संचालित रजिस्ट्री, एक चीज़ जो उन सभी को एक साथ जोड़ती है, वह UDIDI रजिस्ट्री के भीतर विज्ञापित व्यवसायों और सेवाओं को प्रकाशित करने और पता लगाने के लिए एक सामान्य वेब सेवा API है।

एक व्यवसाय या एक कंपनी UDDI रजिस्ट्री में तीन प्रकार की जानकारी दर्ज कर सकती है। यह जानकारी यूडीडीआई के तीन तत्वों में निहित है।

ये तीन तत्व हैं -

  • सफेद पन्ने,
  • पीले पृष्ठ, और
  • ग्रीन पेज।

सफेद पन्ने

सफेद पन्नों में शामिल हैं -

  • कंपनी और उसके व्यवसाय के बारे में बुनियादी जानकारी।

  • बेसिक संपर्क जानकारी जिसमें व्यवसाय का नाम, पता, संपर्क फोन नंबर आदि शामिल हैं।

  • कंपनी कर आईडी के लिए एक विशिष्ट पहचानकर्ता। यह जानकारी दूसरों को आपकी व्यावसायिक पहचान के आधार पर आपकी वेब सेवा की खोज करने की अनुमति देती है।

पीत पृष्ठ

  • पीले पन्नों में कंपनी के बारे में अधिक जानकारी होती है। वे उस प्रकार की इलेक्ट्रॉनिक क्षमताओं का वर्णन शामिल करते हैं जो कंपनी किसी को भी दे सकती है जो इसके साथ व्यापार करना चाहती है।

  • पीले पृष्ठ आमतौर पर स्वीकृत औद्योगिक वर्गीकरण योजनाओं, उद्योग कोड, उत्पाद कोड, व्यवसाय पहचान कोड और कंपनियों के लिए लिस्टिंग के माध्यम से खोज करना और वास्तव में वे जो चाहते हैं उसे ढूंढना पसंद करते हैं।

ग्रीन पेज

हरे पन्नों में एक वेब सेवा के बारे में तकनीकी जानकारी होती है। एक हरे रंग का पृष्ठ किसी व्यक्ति को वेब सेवा से मिल जाने के बाद उसे बांधने की अनुमति देता है। इसमें शामिल हैं -

  • विभिन्न इंटरफेस
  • URL स्थान
  • वेब सेवा को खोजने और चलाने के लिए डिस्कवरी जानकारी और समान डेटा की आवश्यकता होती है।

NOTE- SOD पर आधारित वेब सेवाओं का वर्णन करने के लिए UDDI प्रतिबंधित नहीं है। बल्कि, UDDI का उपयोग किसी भी सेवा का वर्णन करने के लिए किया जा सकता है, एकल वेबपेज या ईमेल पते से लेकर SOAP, CORBA और जावा RMI सेवाओं तक।

UDDI तकनीकी वास्तुकला में तीन भाग शामिल हैं -

UDDI डेटा मॉडल

UDDI डेटा मॉडल व्यवसायों और वेब सेवाओं का वर्णन करने के लिए एक XML स्कीमा है। डेटा मॉडल को "UDDI डेटा मॉडल" अध्याय में विस्तार से वर्णित किया गया है।

UDDI API विशिष्टता

यह UDDI डेटा की खोज और प्रकाशन के लिए एपीआई का एक विनिर्देश है।

UDDI क्लाउड सेवाएँ

ये ऑपरेटर साइटें हैं जो UDDI विनिर्देश के कार्यान्वयन प्रदान करती हैं और एक निर्धारित आधार पर सभी डेटा को सिंक्रनाइज़ करती हैं।

UDDI बिजनेस रजिस्ट्री (UBR), जिसे पब्लिक क्लाउड के रूप में भी जाना जाता है, एक वैचारिक एकल प्रणाली है जो कई नोड्स से निर्मित होती है जिनके प्रतिकृति के माध्यम से उनके डेटा को सिंक्रनाइज़ किया जाता है।

वर्तमान क्लाउड सेवाएं तार्किक रूप से केंद्रीकृत, लेकिन भौतिक रूप से वितरित, निर्देशिका प्रदान करती हैं। इसका मतलब है कि एक रूट नोड को जमा किया गया डेटा स्वचालित रूप से सभी अन्य रूट नोड्स में दोहराया जाएगा। वर्तमान में, डेटा प्रतिकृति हर 24 घंटे में होती है।

UDDI क्लाउड सेवाएँ वर्तमान में Microsoft और IBM द्वारा प्रदान की जाती हैं। अरीबा ने मूल रूप से एक ऑपरेटर की पेशकश करने की योजना बनाई थी, लेकिन तब से प्रतिबद्धता से दूर हो गई है। निकट भविष्य के लिए हेवलेट-पैकर्ड सहित अन्य कंपनियों के अतिरिक्त ऑपरेटरों की योजना बनाई गई है।

निजी UDDI रजिस्ट्रियों को स्थापित करना भी संभव है। उदाहरण के लिए, एक बड़ी कंपनी सभी आंतरिक वेब सेवाओं को पंजीकृत करने के लिए अपनी निजी यूडीडीआई रजिस्ट्री स्थापित कर सकती है। चूंकि इन रजिस्ट्रियों को स्वचालित रूप से रूट यूडीडीआई नोड्स के साथ सिंक्रनाइज़ नहीं किया जाता है, इसलिए उन्हें यूडीडीआई क्लाउड का हिस्सा नहीं माना जाता है।

UDDI में एक XML स्कीमा शामिल है जो निम्नलिखित डेटा संरचनाओं का वर्णन करता है -

  • businessEntity
  • businessService
  • bindingTemplate
  • tModel
  • publisherAssertion

businessEntity डेटा संरचना

व्यवसाय इकाई संरचना वेब सेवाओं के प्रदाता का प्रतिनिधित्व करती है। UDDI रजिस्ट्री के भीतर, इस संरचना में कंपनी के बारे में जानकारी शामिल है, जिसमें संपर्क जानकारी, उद्योग श्रेणियां, व्यवसाय पहचानकर्ता और प्रदान की गई सेवाओं की सूची शामिल है।

यहाँ एक काल्पनिक व्यवसाय की UDDI रजिस्ट्री प्रविष्टि का एक उदाहरण है -

<businessEntity businessKey = "uuid:C0E6D5A8-C446-4f01-99DA-70E212685A40"
   operator = "http://www.ibm.com" authorizedName = "John Doe">
   <name>Acme Company</name>
   <description>
      We create cool Web services
   </description>
	
   <contacts>	
      <contact useType = "general info">
         <description>General Information</description>
         <personName>John Doe</personName>
         <phone>(123) 123-1234</phone>
         <email>[email protected]</email>
      </contact>		
   </contacts>
	
   <businessServices>
      ...
   </businessServices>
   <identifierBag>	
      <keyedReference tModelKey = "UUID:8609C81E-EE1F-4D5A-B202-3EB13AD01823" 
         name = "D-U-N-S" value = "123456789" />
   </identifierBag>
	
   <categoryBag>	
      <keyedReference tModelKey = "UUID:C0B9FE13-179F-413D-8A5B-5004DB8E5BB2" 
         name = "NAICS" value = "111336" />			
   </categoryBag>		
</businessEntity>

बिज़नेस सर्विस डेटा स्ट्रक्चर

व्यवसाय सेवा संरचना व्यवसाय इकाई द्वारा प्रदान की गई एक व्यक्तिगत वेब सेवा का प्रतिनिधित्व करती है। इसके विवरण में वेब सेवा के साथ कैसे जुड़ना है, यह किस प्रकार की वेब सेवा है, और यह किस वर्गीकरण श्रेणी से संबंधित है, इसकी जानकारी शामिल है।

यहाँ हैलो वर्ल्ड वेब सेवा के लिए व्यवसाय सेवा संरचना का एक उदाहरण दिया गया है।

<businessService serviceKey = "uuid:D6F1B765-BDB3-4837-828D-8284301E5A2A"
   businessKey = "uuid:C0E6D5A8-C446-4f01-99DA-70E212685A40">
   <name>Hello World Web Service</name>
   <description>A friendly Web service</description>
   <bindingTemplates>
      ...
   </bindingTemplates>
   <categoryBag />
</businessService>

BusinessKey और serviceKey विशेषताओं में विश्वविद्यालय की विशिष्ट पहचानकर्ताओं (UUIDs) के उपयोग पर ध्यान दें । प्रत्येक व्यवसाय इकाई और व्यवसाय सेवा को विशिष्ट रूप से उन सभी यूडीडीआई रजिस्ट्रियों में पहचाना जाता है, जब रजिस्ट्री द्वारा यूयूआईडी के माध्यम से जानकारी पहले दर्ज की जाती है।

बाइंडमेटप्लेट डेटा संरचना

बाइंडिंग टेम्प्लेट व्यवसाय सेवा संरचना द्वारा प्रस्तुत वेब सेवाओं के तकनीकी विवरण हैं। एकल व्यवसाय सेवा में कई बाध्यकारी टेम्पलेट हो सकते हैं। बाध्यकारी टेम्पलेट वेब सेवा के वास्तविक कार्यान्वयन का प्रतिनिधित्व करता है।

यहाँ हैलो वर्ल्ड के लिए बाध्यकारी टेम्पलेट का एक उदाहरण दिया गया है।

<bindingTemplate serviceKey = "uuid:D6F1B765-BDB3-4837-828D-8284301E5A2A"
   bindingKey = "uuid:C0E6D5A8-C446-4f01-99DA-70E212685A40">
   <description>Hello World SOAP Binding</description>
   <accessPoint URLType = "http">http://localhost:8080</accessPoint>
   
   <tModelInstanceDetails>
      <tModelInstanceInfo tModelKey = "uuid:EB1B645F-CF2F-491f-811A-4868705F5904">
         <instanceDetails>
            <overviewDoc>
               <description>
                  references the description of the WSDL service definition
               </description>
               
               <overviewURL>
                  http://localhost/helloworld.wsdl
               </overviewURL>
            </overviewDoc>
         </instanceDetails>
      </tModelInstanceInfo>
   </tModelInstanceDetails>
</bindingTemplate>

व्यवसाय सेवा में कई बाध्यकारी टेम्पलेट हो सकते हैं, सेवा एक ही सेवा के विभिन्न कार्यान्वयन निर्दिष्ट कर सकती है, प्रत्येक प्रोटोकॉल के एक अलग सेट या एक अलग नेटवर्क पते के लिए बाध्य है।

tModel डेटा संरचना

tModel अंतिम मुख्य डेटा प्रकार है, लेकिन संभवतः इसे समझना सबसे कठिन है। tModel तकनीकी मॉडल के लिए खड़ा है।

tModel UDDI रजिस्ट्री के भीतर संग्रहीत विभिन्न व्यवसाय, सेवा और टेम्पलेट संरचनाओं का वर्णन करने का एक तरीका है। किसी भी अमूर्त अवधारणा को TDodel के रूप में UDDI में पंजीकृत किया जा सकता है। उदाहरण के लिए, यदि आप एक नए WSDL पोर्ट प्रकार को परिभाषित करते हैं, तो आप एक TModel को परिभाषित कर सकते हैं जो UDDI के भीतर उस पोर्ट प्रकार का प्रतिनिधित्व करता है। उसके बाद, आप यह निर्दिष्ट कर सकते हैं कि किसी दिए गए व्यवसाय सेवा को लागू करता है जो उस व्यावसायिक सेवा के बाध्यकारी टेम्प्लेट में से एक के साथ tModel को जोड़कर टाइप करता है।

यहाँ हैलो वर्ल्ड इंटरफ़ेस पोर्ट प्रकार का प्रतिनिधित्व करने वाले tModel का उदाहरण दिया गया है।

<tModel tModelKey = "uuid:xyz987..." operator = "http://www.ibm.com" 
   authorizedName = "John Doe">
   <name>HelloWorldInterface Port Type</name>
   <description>
      An interface for a friendly Web service
   </description>
	
   <overviewDoc>
      <overviewURL>
         http://localhost/helloworld.wsdl
      </overviewURL>
   </overviewDoc>
</tModel>

प्रकाशक डेटा संरचना

यह एक संबंध संरचना है जो एक विशेष प्रकार के संबंधों के अनुसार दो या दो से अधिक व्यवसायिक संरचनाओं को जोड़ती है, जैसे कि सहायक या विभाग।

प्रकाशक की संरचना संरचना में तीन तत्व शामिल हैं: fromKey (पहला businessKey), toKey (दूसरा businessKey), और keyedReference।

KeyedReference एक tModel के भीतर एक keyMame keyValue जोड़ी के संदर्भ में मुखर संबंध प्रकार को निर्दिष्ट करता है, जिसे tModelKey द्वारा विशिष्ट रूप से संदर्भित किया जाता है।

<element name = "publisherAssertion" type = "uddi:publisherAssertion" />
<complexType name = "publisherAssertion">
   <sequence>
      <element ref = "uddi:fromKey" />
      <element ref = "uddi:toKey" />
      <element ref = "uddi:keyedReference" />
   </sequence>
</complexType>

एक रजिस्ट्री का उपयोग करने के लिए कुछ तरीके के बिना कोई फायदा नहीं है। UDDI मानक संस्करण 2.0 रजिस्ट्री के साथ बातचीत करने के लिए सेवा उपभोक्ताओं और सेवा प्रदाताओं के लिए दो इंटरफेस निर्दिष्ट करता है।

सेवा उपभोक्ता उपयोग करते हैं Inquiry Interface सेवा खोजने के लिए, और सेवा प्रदाता उपयोग करते हैं Publisher Interface किसी सेवा को सूचीबद्ध करने के लिए।

UDDI इंटरफ़ेस का मुख्य UDDI XML स्कीमा परिभाषाएँ है। ये मूलभूत UDDI डेटा प्रकारों को परिभाषित करते हैं जिनके माध्यम से सभी जानकारी बहती है।

प्रकाशक इंटरफ़ेस

प्रकाशक इंटरफ़ेस UDDI रजिस्ट्री में अपनी प्रविष्टियों का प्रबंधन करने वाले सेवा प्रदाता के लिए सोलह परिचालनों को परिभाषित करता है -

  • get_authToken- एक प्राधिकरण टोकन को पुनः प्राप्त करता है। सभी प्रकाशक इंटरफ़ेस संचालन के लिए आवश्यक है कि अनुरोध के साथ एक वैध प्राधिकरण टोकन जमा किया जाए।

  • discard_authToken- यूडीडीआई रजिस्ट्री को किसी दिए गए प्राधिकरण टोकन को स्वीकार नहीं करना बताता है। यह चरण सिस्टम से लॉग आउट करने के बराबर है।

  • save_business - UDDI रजिस्ट्री में शामिल किसी व्यावसायिक इकाई की जानकारी बनाता या अपडेट करता है।

  • save_service - एक व्यावसायिक इकाई प्रदान करने वाली वेब सेवाओं के बारे में जानकारी बनाता या अपडेट करता है।

  • save_binding - वेब सेवा के कार्यान्वयन के बारे में तकनीकी जानकारी बनाता या अपडेट करता है।

  • save_tModel - UDDI रजिस्ट्री द्वारा प्रबंधित अमूर्त अवधारणाओं के पंजीकरण को बनाता या अपडेट करता है।

  • delete_business - यूडीडीआई रजिस्ट्री से दिए गए व्यापार संस्थाओं को पूरी तरह से हटा देता है।

  • delete_service - यूडीडीआई रजिस्ट्री से दी गई वेब सेवाओं को पूरी तरह से हटा देता है।

  • delete_binding - यूडीडीआई रजिस्ट्री से दी गई वेब सेवाओं की तकनीकी जानकारी निकालता है।

  • delete_tModel - UDDI रजिस्ट्री से निर्दिष्ट tModels को हटाता है।

  • get_registeredInfo - सब कुछ का एक सारांश लौटाता है UDDI रजिस्ट्री वर्तमान में सभी व्यवसायों, सभी सेवाओं और सभी tModels सहित उपयोगकर्ता के लिए नज़र रख रही है।

  • set_publisherAssertions - अलग-अलग प्रकाशक खाते से जुड़े सभी ट्रैक किए गए संबंध अभिकथनों का प्रबंधन करता है।

  • add_publisherAssertions - एक या एक से अधिक प्रकाशकों को एक व्यक्तिगत प्रकाशक के संग्रह में जोड़े जाने का कारण बनता है।

  • delete_publisherAssertions - प्रकाशक के जोर के संग्रह से एक या एक से अधिक प्रकाशकों को निकालने वाले तत्वों का कारण बनता है।

  • get_assertionStatusReport - व्यक्तिगत प्रकाशक खाते द्वारा प्रबंधित किसी भी व्यवसाय पंजीकरण को शामिल करने वाले वर्तमान और बकाया प्रकाशक की स्थिति का निर्धारण करने के लिए प्रशासनिक सहायता प्रदान करता है।

  • get_publisherAssertions - एक व्यक्तिगत प्रकाशक खाते के साथ जुड़े प्रकाशक के दावे का पूरा सेट प्राप्त करता है।

पूछताछ इंटरफ़ेस

यूडीडीआई रजिस्ट्री की खोज और विशिष्ट पंजीकरणों के बारे में विवरण प्राप्त करने के लिए पूछताछ इंटरफ़ेस दस कार्यों को परिभाषित करता है -

  • find_binding - उन वेब सेवाओं की सूची लौटाता है जो तकनीकी बाइंडिंग जानकारी के आधार पर मानदंडों के एक विशेष सेट से मेल खाती हैं।

  • find_business - उन व्यापारिक संस्थाओं की सूची लौटाता है जो मानदंडों के एक विशेष सेट से मेल खाते हैं।

  • find_ltservice - उन वेब सेवाओं की सूची लौटाता है जो मानदंडों के एक विशेष सेट से मेल खाती हैं।

  • find_tModel - tModels की एक सूची देता है जो मानदंडों के एक विशेष सेट से मेल खाता है।

  • get_bindingDetail - किसी विशेष वेब सेवा बाध्यकारी टेम्पलेट के लिए पूर्ण पंजीकरण जानकारी देता है।

  • get_businessDetail - एक व्यावसायिक इकाई के लिए पंजीकरण जानकारी लौटाता है, जिसमें सभी सेवाएं प्रदान करती हैं, जो इकाई प्रदान करती है।

  • get_businessDetailExt - एक व्यावसायिक इकाई के लिए पूर्ण पंजीकरण जानकारी देता है।

  • get_serviceDetail - एक वेब सेवा के लिए पूर्ण पंजीकरण जानकारी देता है।

  • get_tModelDetail - एक tModel के लिए पूर्ण पंजीकरण जानकारी देता है।

  • find_relatedBusinesses - उन व्यवसायों को उजागर करता है जो uddi-org के माध्यम से संबंधित हैं: रिश्ते मॉडल।

एक कंपनी पर विचार करें XYZ UDDI के साथ अपनी संपर्क जानकारी, सेवा विवरण, और ऑनलाइन सेवा एक्सेस जानकारी पंजीकृत करना चाहता है। निम्नलिखित कदम आवश्यक हैं -

  • एक ऑपरेटर चुनें जिसके साथ काम करना है। प्रत्येक ऑपरेटर के पास रजिस्ट्री की अपनी प्रतिकृति तक पहुंच को अधिकृत करने के लिए अलग-अलग नियम और शर्तें हैं।

  • बिल्ड या अन्यथा एक UDDI क्लाइंट प्राप्त करें, जैसे कि ऑपरेटरों द्वारा प्रदान किया गया।

  • ऑपरेटर से प्रमाणीकरण टोकन प्राप्त करें।

  • व्यवसाय के बारे में जानकारी पंजीकृत करें। मैचों के लिए खोज करने वालों के लिए उपयोगी हो सकती है के रूप में अधिक जानकारी शामिल करें।

  • प्रमाणीकरण टोकन जारी करें।

  • बाइंडिंग टेम्प्लेट जानकारी सहित सूचना की पुनर्प्राप्ति का परीक्षण करने के लिए पूछताछ एपीआई का उपयोग करें, यह सुनिश्चित करने के लिए कि कोई व्यक्ति जो इसे प्राप्त करता है वह आपकी सेवा के साथ बातचीत करने के लिए इसका सफलतापूर्वक उपयोग कर सकता है।

  • यदि कोई किसी दी गई सेवा की खोज करना चाहता है और सेवा प्रदाताओं में से एक के रूप में अपना व्यवसाय ढूंढना चाहता है तो tModel जानकारी भरें।

  • हर बार ऑपरेटर से एक नया प्रमाणीकरण टोकन प्राप्त करने और जारी करने, बदलते व्यापार संपर्क जानकारी और नई सेवा के विवरण को प्रतिबिंबित करने के लिए आवश्यक के रूप में जानकारी को अपडेट करें। जब भी आपको अपने पंजीकृत डेटा को अपडेट या संशोधित करने की आवश्यकता होती है, तो आपको उस ऑपरेटर पर वापस जाना होगा जिसके साथ आपने डेटा दर्ज किया है।

निम्नलिखित उदाहरणों से पता चलेगा कि XYZ कंपनी अपनी जानकारी को कैसे पंजीकृत करेगी और XYZ की उत्पाद लाइन को ले जाने में रुचि रखने वाले एक वितरक को कैसे XYZ.com वेब सेवाओं का उपयोग करके कंपनी से संपर्क करने और ऑर्डर देने के बारे में जानकारी मिल सकती है।

रजिस्ट्री बनाना

Microsoft ऑपरेटरों में से एक से एक प्रमाणीकरण टोकन प्राप्त करने के बाद, उदाहरण के लिए XYZ.com डेवलपर्स तय करते हैं कि रजिस्ट्री को किस सूचना को प्रकाशित करना है और Microsoft द्वारा प्रदान किए गए एक UDDI टूल का उपयोग करना है। यदि आवश्यक हो, तो डेवलपर्स उचित SOAP संदेश उत्पन्न करने के लिए जावा, C # या VB.NET प्रोग्राम भी लिख सकते हैं। यहाँ एक उदाहरण है।

POST /save_business HTTP/1.1
Host: www.XYZ.com
Content-Type: text/xml; charset = "utf-8"
Content-Length: nnnn
SOAPAction: "save_business"

<?xml version = "1.0" encoding = "UTF-8" ?>
<Envelope xmlns = "http://schemas/xmlsoap.org/soap/envelope/">
   <Body>
      <save_business generic = "2.0" xmlns = "urn:uddi-org:api_v2">
         <businessKey = "">
         </businessKey>
         
         <name>
            XYZ, Pvt Ltd.
         </name>
         
         <description>
            Company is involved in giving Stat-of-the-art....
         </description>
         
         <identifierBag> ... </identifierBag>
         ...
      </save_business>
   </Body>
</Envelope>

यह उदाहरण एक SOAP संदेश दिखाता है जो XYZ कंपनी के लिए UDDI व्यवसाय इकाई को पंजीकृत करने का अनुरोध करता है। मुख्य तत्व रिक्त है, क्योंकि ऑपरेटर स्वचालित रूप से डेटा संरचना के लिए UUID कुंजी बनाता है। अधिकांश क्षेत्रों को एक साधारण उदाहरण दिखाने के लिए छोड़ दिया जाता है।

कंपनी XYZ हमेशा एक व्यावसायिक इकाई बनाने के लिए आवश्यक बुनियादी जानकारी को जोड़ने के लिए एक और save_business ऑपरेशन निष्पादित कर सकती है।

जानकारी प्राप्त करना

XYZ कंपनी द्वारा प्रासंगिक जानकारी के साथ अपनी UDDI प्रविष्टि को अपडेट करने के बाद, जो कंपनियां XYZ वितरक बनना चाहती हैं, वे UDDI रजिस्ट्री में संपर्क जानकारी देख सकती हैं और XYZ ऑनलाइन प्रकाशित होने वाली दो वेब सेवाओं के लिए सेवा विवरण और एक्सेस पॉइंट प्राप्त कर सकती हैं। ऑर्डर प्रविष्टि: थोक आदेश और इन-सीज़न रीकोकिंग आदेशों को निर्धारित करता है।

यह उदाहरण XYZ कंपनी के बारे में व्यावसायिक विस्तार से जानकारी प्राप्त करने के लिए एक नमूना SOAP अनुरोध दिखाता है। एक बार जब आप UUID, या कुंजी, विशिष्ट व्यवसाय के लिए पंजीकृत हो जाते हैं, तो आप इसे उस व्यवसाय के बारे में विशेष जानकारी वापस पाने के लिए get_businessDetail API में उपयोग कर सकते हैं।

POST /get_businessDetail HTTP/1.1
Host: www.XYZ.com
Content-Type: text/xml; charset = "utf-8"
Content-Length: nnnn
SOAPAction: "get_businessDetail"

<?xml version = "1.0" encoding = "UTF-8" ?>
<Envelope xmlns = "http://schemas/xmlsoap.org/soap/envelope/">
   <Body>
      <get_businessDetail generic = "2.0" xmlns = "urn:uddi-org:api_v2">
         <businessKey = "C90D731D-772HSH-4130-9DE3-5303371170C2">
         </businessKey>
      </get_businessDetail>
   </Body>
</Envelope>

UDDI डेटा मॉडल एक व्यवसाय और इसके द्वारा प्रकाशित वेब सेवाओं के बारे में जानकारी संग्रहीत करने के लिए एक सामान्य संरचना को परिभाषित करता है। UDDI डेटा मॉडल पूरी तरह से एक्स्टेंसिबल है, जिसमें सूचना के कई दोहराए जाने वाले अनुक्रम संरचनाएं शामिल हैं।

हालांकि, WSDL का उपयोग किसी वेब सेवा के इंटरफ़ेस का वर्णन करने के लिए किया जाता है। WSDL UDDI के साथ उपयोग करने के लिए काफी सरल है।

  • WSDL को UDDI में बिज़नेस सर्विस, बाइंडिंगटेम्पलेट और tModel सूचना के संयोजन का उपयोग करते हुए दर्शाया गया है ।

  • UDDI में पंजीकृत किसी भी सेवा के रूप में, सेवा के बारे में सामान्य जानकारी BusinessService डेटा संरचना में संग्रहीत होती है, और यह जानकारी विशिष्ट होती है कि सेवा को कैसे और कहाँ एक्सेस किया जाता है, एक या अधिक संबद्ध बाइंडप्लेट संरचनाओं में संग्रहीत होती है। प्रत्येक बाइंडिंगप्लेट संरचना में एक तत्व शामिल होता है जिसमें सेवा का नेटवर्क पता होता है और इसके साथ एक या एक से अधिक tModel संरचनाएं जुड़ी होती हैं जो सेवा का वर्णन और विशिष्ट पहचान करती हैं।

  • UDDI दुकान डबल्यूएसडीएल जानकारी, या डबल्यूएसडीएल फ़ाइलों की ओर इशारा करने के लिए इस्तेमाल किया जाता है, tModel के रूप में प्रकार प्रथा के अनुसार को भेजा जाना चाहिए wsdlSpec , जिसका अर्थ है कि overviewDoc तत्व स्पष्ट रूप से एक डबल्यूएसडीएल सेवा इंटरफ़ेस परिभाषा की ओर इशारा करते के रूप में पहचान की है।

  • UDDI के लिए, WSDL सामग्री को इंटरफ़ेस फ़ाइल और कार्यान्वयन फ़ाइल के दो प्रमुख तत्वों में विभाजित किया गया है।

हर्ट्ज आरक्षण प्रणाली वेब सेवा एक ठोस उदाहरण प्रदान करती है कि UDDI और WSDL एक साथ कैसे काम करते हैं। यहाँ इस वेब सेवा के लिए <tModel> है -

<tModel authorizedName = "..." operator = "..." tModelKey = "...">
   <name>HertzReserveService</name>
   <description xml:lang = "en">
      WSDL description of the Hertz reservation service interface
   </description>
	
   <overviewDoc>
      <description xml:lang = "en">
         WSDL source document.
      </description>
      <overviewURL>
         http://mach3.ebphost.net/wsdl/hertz_reserve.wsdl
      </overviewURL>
   </overviewDoc>
   
   <categoryBag>
      <keyedReference tModelKey = "uuid:C1ACF26D-9672-4404-9D70-39B756E62AB4"
         keyName = "uddi-org:types" keyValue = "wsdlSpec"/>
   </categoryBag>	
</tModel>

प्रमुख बिंदु हैं -

  • सिंहावलोकन तत्व URL को वह स्थान देता है जहाँ सर्विस इंटरफ़ेस परिभाषा WSDL फ़ाइल पाई जा सकती है। यह मानव और UDDI / WSDL जागरूक टूल को सेवा इंटरफ़ेस परिभाषा का पता लगाने की अनुमति देता है।

  • श्रेणीबाग में कीरेडरेंस तत्व का उद्देश्य यह सुनिश्चित करना है कि इस tModel को WSDL विनिर्देश दस्तावेज के रूप में वर्गीकृत किया गया है।

वर्तमान में कई UDDI कार्यान्वयन उपलब्ध हैं। ये कार्यान्वयन UDDI API की जटिलताओं में बिना तार के UDDI डेटा को खोजना या प्रकाशित करना आसान बनाते हैं। यहाँ मुख्य UDDI कार्यान्वयन का एक संक्षिप्त सारांश उपलब्ध है।

जावा कार्यान्वयन

जावा के लिए दो UDDI कार्यान्वयन हैं।

  • UDDI4J (जावा के लिए UDDI) - UDDI4J मूल रूप से IBM द्वारा बनाया गया था। जनवरी 2001 में, आईबीएम ने कोड को अपने स्वयं के ओपन सोर्स साइट पर बदल दिया। UDDI4J एक जावा क्लास लाइब्रेरी है जो UDDI के साथ बातचीत करने के लिए एक एपीआई प्रदान करता है।

  • jUDDI - jUDDI एक UDDI रजिस्ट्री का एक खुला स्रोत जावा कार्यान्वयन और UDDI सेवाओं तक पहुँचने के लिए एक टूलकिट है।

पर्ल इम्प्लीमेंटेशन

  • UDDI::Lite - यह जांच और प्रकाशन के लिए एक बुनियादी UDDI ग्राहक प्रदान करता है।

रूबी कार्यान्वयन

  • UDDI4r - यह जांच और प्रकाशन के लिए एक बुनियादी UDDI ग्राहक प्रदान करता है।

पायथन कार्यान्वयन

  • UDDI4Py - UDDI4Py एक पायथन पैकेज है, जो UDDI संस्करण 2 API से प्रतिक्रियाओं के भेजने और प्रसंस्करण की अनुमति देता है।

UDDI प्रोजेक्ट XML स्कीमा परिभाषाओं के एक सेट को परिभाषित करता है जो विभिन्न विनिर्देश API द्वारा उपयोग किए जाने वाले डेटा स्वरूपों का वर्णन करता है। ये दस्तावेज़ www.uddi.org पर डाउनलोड के लिए उपलब्ध हैं । सभी विनिर्देश समूहों का वर्तमान संस्करण संस्करण 2.0 है।

विनिर्देशों में निम्नलिखित शामिल हैं -

  • UDDI प्रतिकृति,
  • UDDI ऑपरेटरों,
  • UDDI प्रोग्रामर एपीआई, और
  • UDDI डेटा संरचनाएं

UDDI प्रतिकृति

यह दस्तावेज़ डेटा प्रतिकृति प्रक्रियाओं और इंटरफेस का वर्णन करता है, जिसके लिए एक रजिस्ट्री ऑपरेटर को साइटों के बीच डेटा प्रतिकृति प्राप्त करने के लिए अनुरूप होना चाहिए। यह विनिर्देश प्रोग्रामर का एपीआई नहीं है; यह UBR नोड्स के बीच प्रयुक्त प्रतिकृति तंत्र को परिभाषित करता है।

UDDI ऑपरेटर्स

यह दस्तावेज़ UDDI नोड ऑपरेटरों द्वारा आवश्यक व्यवहार और परिचालन मापदंडों को रेखांकित करता है। यह विनिर्देश डेटा प्रबंधन आवश्यकताओं को परिभाषित करता है जिसके लिए ऑपरेटरों को पालन करना होगा।

UDDI प्रोग्रामर की एपीआई

यह विनिर्देश फ़ंक्शन के एक सेट को परिभाषित करता है जो सभी UDDI रजिस्ट्री में होस्ट की गई सेवाओं के बारे में पूछताछ करने और किसी व्यवसाय या रजिस्ट्री के लिए सेवा के बारे में जानकारी प्रकाशित करने के लिए समर्थन करता है। यह विनिर्देश XML दस्तावेजों वाले SOAP संदेशों की एक श्रृंखला को परिभाषित करता है जो एक UDDI रजिस्ट्री स्वीकार करता है, पार्स करता है, और प्रतिक्रिया करता है। यह विनिर्देश UDDI XML API स्कीमा और UDDI डेटा संरचना विनिर्देश के साथ, UDDI रजिस्ट्री के लिए एक पूर्ण प्रोग्रामिंग इंटरफ़ेस बनाता है।

UDDI डेटा संरचनाएं

यह विनिर्देश UDDI प्रोग्रामर के एपीआई द्वारा परिभाषित SOAP संदेशों के भीतर निहित XML संरचनाओं की बारीकियों को शामिल करता है। यह विनिर्देश पांच मुख्य डेटा संरचनाओं और उनके संबंधों को एक दूसरे के साथ परिभाषित करता है।

UDDI XML API स्कीमा किसी विनिर्देश में सम्‍मिलित नहीं है; बल्कि, यह एक XML स्कीमा दस्तावेज़ के रूप में संग्रहीत है जो UDDI डेटा संरचनाओं की संरचना और डेटाटिप्स को परिभाषित करता है।

इस ट्यूटोरियल में यूडीडीआई और उसके तत्व और यूडीडीआई का पूरा आर्किटेक्चर और डेटा मॉडल भी देखा है।

हमने दो UDDI इंटरफेस के बारे में सीखा है: प्रकाशक का इंटरफ़ेस और पूछताछ इंटरफ़ेस। हमने UDDI के साथ वेब सेवाओं के लिए पंजीकरण और खोज करना भी सीखा है।

आगे क्या होगा?

अगला कदम SOAP, WSDL और वेब सेवाओं के बारे में जानना है।

साबुन

SOAP एक सरल XML- आधारित प्रोटोकॉल है जो एप्लिकेशन को HTTP पर जानकारी का आदान-प्रदान करने की अनुमति देता है।

यदि आप SOAP के बारे में अधिक जानना चाहते हैं, तो कृपया हमारे SOAP ट्यूटोरियल पर जाएँ ।

डबल्यूएसडीएल

WSDL XML प्रारूप में एक वेब सेवा का वर्णन करने के लिए मानक प्रारूप है।

WSDL UDDI का एक अभिन्न अंग है।

यदि आप WSDL के बारे में अधिक जानना चाहते हैं, तो कृपया हमारे WSDL ट्यूटोरियल पर जाएँ ।

वेब सेवाएं

वेब सेवाएँ आपके अनुप्रयोगों को वेब-अनुप्रयोगों में परिवर्तित कर सकती हैं।

यदि आप वेब सेवाओं के बारे में अधिक जानना चाहते हैं, तो कृपया हमारे वेब सेवा ट्यूटोरियल पर जाएँ ।

यहाँ UDDI पूछताछ API और UDDI प्रकाशन API का पूरा संदर्भ दिया गया है।

UDDI पूछताछ एपीआई

एपीआई का नाम विवरण V1.0 V2.0
find_binding एक निर्दिष्ट सेवा से जुड़े टेम्पलेट बाइंडिंग के लिए खोजें। Y Y
find_business व्यवसाय के लिए खोजें जो निर्दिष्ट मानदंडों से मेल खाती हैं। Y Y
find_relatedBusinesses ऐसे व्यवसाय को छोड़ देता है जो uddi-org: रिलेशनशिप मॉडल के माध्यम से संबंधित रहा है। Y
find_service निर्दिष्ट व्यवसाय से जुड़ी सेवा के लिए खोजें। Y Y
find_tModel TModel रिकॉर्ड की खोज जो निर्दिष्ट मानदंडों से मेल खाती है। Y Y
get_bindingDetail प्रत्येक निर्दिष्ट बाइंडिंग के लिए पूर्ण बाइंडिंगप्लेट को पुनः प्राप्त करता है। Y Y
get_businessDetail प्रत्येक निर्दिष्ट BusinessKey के लिए संपूर्ण व्यवसाय पुनर्प्राप्त करता है। Y Y
get_businessDetailExt प्रत्येक निर्दिष्ट BusinessKey के लिए विस्तारित व्यवसाय को पुनः प्राप्त करता है। Y Y
get_serviceDetail प्रत्येक निर्दिष्ट सेवा के लिए BusinessService रिकॉर्ड पुनर्प्राप्त करता है। Y Y
get_tModelDetail प्रत्येक निर्दिष्ट tModelKey के लिए tModel रिकॉर्ड को पुनः प्राप्त करता है। Y Y

UDDI प्रकाशन एपीआई

एपीआई का नाम विवरण V1.0 V2.0
get_authToken एक प्राधिकरण टोकन को पुनः प्राप्त करता है। सभी प्रकाशक इंटरफ़ेस संचालन के लिए आवश्यक है कि अनुरोध के साथ एक वैध प्राधिकरण टोकन जमा किया जाए। Y Y
discard_authToken UDDI रजिस्ट्री को अब दिए गए प्राधिकरण टोकन को स्वीकार नहीं करता है। यह चरण सिस्टम से लॉग आउट करने के बराबर है। Y Y
save_business UDDI रजिस्ट्री में शामिल किसी व्यावसायिक इकाई की जानकारी बनाता या अद्यतन करता है। Y Y
save_service एक व्यावसायिक इकाई प्रदान करने वाली वेब सेवाओं के बारे में जानकारी बनाता या अपडेट करता है। Y Y
save_binding वेब सेवा के कार्यान्वयन के बारे में तकनीकी जानकारी बनाता या अपडेट करता है। Y Y
save_tModel UDDI रजिस्ट्री द्वारा प्रबंधित अमूर्त अवधारणाओं के पंजीकरण को बनाता या अपडेट करता है। Y Y
delete_business यूडीडीआई रजिस्ट्री से दिए गए व्यापार संस्थाओं को पूरी तरह से हटा देता है। Y Y
delete_service UDDI रजिस्ट्री से दी गई वेब सेवाओं को पूरी तरह से हटा देता है। Y Y
delete_binding UDDI रजिस्ट्री से दी गई वेब सेवा तकनीकी विवरणों को हटा देती है। Y Y
delete_tModel UDDI रजिस्ट्री से निर्दिष्ट tModels को निकालता है। Y Y
get_registeredInfo वर्तमान में UDDI रजिस्ट्री सब कुछ का एक सारांश लौटाती है, वर्तमान में सभी व्यवसायों, सभी सेवाओं और सभी tMelsels सहित उपयोगकर्ता के लिए नज़र रख रही है। Y Y
set_publisherAssertions एक व्यक्तिगत प्रकाशक खाते से जुड़े ट्रैक किए गए सभी संबंधों का प्रबंधन करता है। Y
add_publisherAssertions एक या एक से अधिक प्रकाशकों को एक व्यक्तिगत प्रकाशक के संग्रह में जोड़े जाने का कारण बनता है। Y
delete_publisherAssertions प्रकाशक के जोर के संग्रह से एक या एक से अधिक प्रकाशकों के तत्व निकाले जाते हैं। Y
get_assertionStatusReport व्यक्तिगत प्रकाशक खाते द्वारा प्रबंधित किसी भी व्यवसाय पंजीकरण को शामिल करने वाले वर्तमान और बकाया प्रकाशक की स्थिति का निर्धारण करने के लिए प्रशासनिक सहायता प्रदान करता है। Y
get_publisherAssertions एक प्रकाशक प्रकाशक के पूर्ण सेट को प्राप्त करता है जो एक व्यक्तिगत प्रकाशक खाते से जुड़ा होता है। Y

त्रुटि कोड संदर्भ

UDDI API द्वारा दिए गए त्रुटि कोड का पूरा संदर्भ इस प्रकार है -

त्रुटि कोड