रूबी के साथ वेब सेवाएँ - SOAP4R

SOAP क्या है?

सरल ऑब्जेक्ट एक्सेस प्रोटोकॉल (SOAP), एक क्रॉस-प्लेटफ़ॉर्म और भाषा-स्वतंत्र RPC प्रोटोकॉल है जो XML पर आधारित है और आमतौर पर (लेकिन आवश्यक नहीं) HTTP है।

यह एक्सएमएल का उपयोग उन सूचनाओं को एनकोड करने के लिए करता है जो दूरस्थ प्रक्रिया कॉल और HTTP को क्लाइंट से सर्वरों तक एक नेटवर्क में और इसके विपरीत ट्रांसपोर्ट करने के लिए करती है।

SOAP के अन्य तकनीकों जैसे COM, CORBA आदि पर कई फायदे हैं: उदाहरण के लिए, इसकी अपेक्षाकृत सस्ती तैनाती और डिबगिंग लागत, इसकी एक्स्टेंसिबिलिटी और आसानी का उपयोग, और विभिन्न भाषाओं और प्लेटफार्मों के लिए कई कार्यान्वयनों का अस्तित्व।

कृपया इसे विस्तार से समझने के लिए हमारे सरल ट्यूटोरियल SOAP का संदर्भ लें ।

यह अध्याय आपको रूबी (SOAP4R) के लिए SOAP कार्यान्वयन से परिचित कराता है। यह एक बुनियादी ट्यूटोरियल है, इसलिए यदि आपको एक गहन विवरण की आवश्यकता है, तो आपको अन्य संसाधनों को संदर्भित करने की आवश्यकता होगी।

SOAP4R स्थापित करना

SOAP4R हिरोशी नाकामुरा द्वारा विकसित रूबी के लिए SOAP कार्यान्वयन है और इससे डाउनलोड किया जा सकता है -

NOTE - एक महान मौका हो सकता है कि आपने पहले से ही इस घटक को स्थापित किया हो।

Download SOAP

अगर आपको पता है gem उपयोगिता तब आप SOAP4R और संबंधित पैकेजों को स्थापित करने के लिए निम्न कमांड का उपयोग कर सकते हैं।

$ gem install soap4r --include-dependencies

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

SOAP4R सर्वर लेखन

SOAP4R दो अलग-अलग प्रकार के सर्वरों का समर्थन करता है -

  • CGI / FastCGI आधारित (SOAP :: RPC :: CGIStub)
  • स्टैंडअलोन (SOAP :: RPC: स्टैंडअलोन सेवर)

यह अध्याय एक स्टैंड अलोन सर्वर लिखने पर विस्तार देता है। एक SOAP सर्वर लिखने में निम्नलिखित चरण शामिल हैं।

चरण 1 - इनहेरिट SOAP :: RPC :: स्टैंडअलोन सेवर क्लास

अपने खुद के योग्य स्वतंत्र सर्वर को लागू करने के लिए आप एक नया वर्ग, जिनमें से बच्चे को हो जाएगा लिखने की ज़रूरत सोप :: StandaloneServer इस प्रकार है -

class MyServer < SOAP::RPC::StandaloneServer
  ...............
end

NOTE- यदि आप FastCGI आधारित सर्वर लिखना चाहते हैं तो आपको SOAP :: RPC :: CGIStub को मूल वर्ग के रूप में लेना होगा, बाकी प्रक्रिया वही रहेगी।

चरण 2 - हैंडलर विधियों को परिभाषित करें

दूसरा कदम है अपनी वेब सेवा विधियों को लिखना, जिन्हें आप बाहरी दुनिया के सामने लाना चाहते हैं।

उन्हें सरल रूबी विधियों के रूप में लिखा जा सकता है। उदाहरण के लिए, दो संख्याओं को जोड़ने और दो संख्याओं को विभाजित करने के लिए दो तरीके लिखते हैं -

class MyServer < SOAP::RPC::StandaloneServer
   ...............

   # Handler methods
   def add(a, b)
      return a + b
   end
   def div(a, b) 
      return a / b 
   end
end

चरण 3 - हैंडलर विधियों को उजागर करें

अगला कदम हमारे सर्वर में हमारे परिभाषित तरीकों को जोड़ना है। इनिशियलाइज़ विधि दो निम्न विधियों में से एक के साथ सेवा के तरीकों का पर्दाफाश करने के लिए किया जाता है -

class MyServer < SOAP::RPC::StandaloneServer
   def initialize(*args)
      add_method(receiver, methodName, *paramArg)
   end
end

यहाँ मापदंडों का वर्णन है -

अनु क्रमांक। पैरामीटर और विवरण
1

receiver

ऑब्जेक्ट जिसमें MethodName विधि है। आप एक ही वर्ग में सेवा विधियों को मेथडिफ विधि के रूप में परिभाषित करते हैं, यह पैरामीटर स्व है

2

methodName

उस विधि का नाम जिसे RPC अनुरोध के कारण कहा जाता है।

3

paramArg

निर्दिष्ट किया जाता है, जब दिया जाता है, पैरामीटर नाम और पैरामीटर मोड।

इनआउट या आउट पैरामीटर के उपयोग को समझने के लिए , निम्न सेवा विधि पर विचार करें जो दो पैरामीटर (inParam और inoutParam) को लेती है, एक सामान्य रिटर्न मान (retVal) और दो और पैरामीटर: inoutParam और outParam -

def aMeth(inParam, inoutParam)
   retVal = inParam + inoutParam
   outParam = inParam . inoutParam
   inoutParam = inParam * inoutParam
   return retVal, inoutParam, outParam
end

अब, हम इस विधि को निम्नानुसार उजागर कर सकते हैं -

add_method(self, 'aMeth', [
   %w(in inParam),
   %w(inout inoutParam),
   %w(out outParam),
   %w(retval return)
])

चरण 4 - सर्वर शुरू करें

अंतिम चरण अपने सर्वर को व्युत्पन्न वर्ग और कॉलिंग के एक उदाहरण को तुरंत शुरू करके शुरू करना है start तरीका।

myServer = MyServer.new('ServerName', 'urn:ruby:ServiceName', hostname, port)

myServer.start

यहाँ आवश्यक मापदंडों का वर्णन है -

अनु क्रमांक। पैरामीटर और विवरण
1

ServerName

एक सर्वर नाम, आप जो सबसे अधिक पसंद करते हैं वह दे सकते हैं।

2

urn:ruby:ServiceName

यहाँ कलश: माणिक स्थिर है लेकिन आप इस सर्वर के लिए एक अद्वितीय सेवानाम दे सकते हैं।

3

hostname

होस्टनाम निर्दिष्ट करता है जिस पर यह सर्वर सुनेंगे।

4

port

वेब सेवा के लिए उपलब्ध पोर्ट नंबर।

उदाहरण

अब, उपरोक्त चरणों का उपयोग करते हुए, हम एक स्टैंडअलोन सर्वर लिखते हैं -

require "soap/rpc/standaloneserver"

begin
   class MyServer < SOAP::RPC::StandaloneServer

      # Expose our services
      def initialize(*args)
         add_method(self, 'add', 'a', 'b')
         add_method(self, 'div', 'a', 'b')
      end

      # Handler methods
      def add(a, b)
         return a + b
      end
      def div(a, b) 
         return a / b 
      end
end
   server = MyServer.new("MyServer", 
            'urn:ruby:calculation', 'localhost', 8080)
   trap('INT){
      server.shutdown
   }
   server.start
rescue => err
   puts err.message
end

जब मार डाला, इस सर्वर अनुप्रयोग पर स्टैंडअलोन सोप सर्वर शुरू होता है स्थानीय होस्ट और पर अनुरोध के लिए सुनता पोर्ट 8080 यह एक सेवा के तरीकों, को उजागर करता है जोड़ने और div है, जो दो पैरामीटर लेता है और परिणाम लौटने।

अब, आप इस सर्वर को पृष्ठभूमि में इस प्रकार चला सकते हैं -

$ ruby MyServer.rb&

लेखन SOAP4R ग्राहक

सोप :: RPC :: चालक वर्ग सोप क्लाइंट अनुप्रयोग लिखने के लिए सहायता प्रदान करता है। यह अध्याय इस वर्ग का वर्णन करता है और एक अनुप्रयोग के आधार पर इसके उपयोग को प्रदर्शित करता है।

निम्नलिखित नंगे न्यूनतम जानकारी के लिए आपको SOAP सेवा पर कॉल करना होगा -

  • SOAP सेवा का URL (SOAP समापन बिंदु URL)।
  • सेवा विधियों के नामस्थान (विधि नामस्थान URI)।
  • सेवा विधियों और उनके मापदंडों के नाम।

अब, हम एक SOAP क्लाइंट लिखेंगे जो उपरोक्त उदाहरण में परिभाषित सेवा विधियों को कॉल करेगा, जिसका नाम ऐड और डिव होगा

SOAP क्लाइंट बनाने के लिए यहाँ मुख्य चरण हैं।

चरण 1 - एक SOAP ड्राइवर इंस्टेंस बनाएँ

हम का एक उदाहरण बनाने सोप :: RPC :: चालक अपनी नई विधि बुला इस प्रकार से -

SOAP::RPC::Driver.new(endPoint, nameSpace, soapAction)

यहाँ आवश्यक मापदंडों का वर्णन है -

अनु क्रमांक। पैरामीटर और विवरण
1

endPoint

से कनेक्ट करने के लिए SOAP सर्वर का URL।

2

nameSpace

इस SOAP :: RPC :: ड्रायवर ऑब्जेक्ट के साथ किए गए सभी RPC के लिए उपयोग करने का नामस्थान।

3

soapAction

HTTP हेडर के SOAPAction फ़ील्ड का मान। यदि यह डिफॉल्ट खाली स्ट्रिंग "" के लिए है।

चरण 2 - सेवा विधियाँ जोड़ें

SOAP :: RPC :: ड्राइवर के लिए SOAP सेवा विधि जोड़ने के लिए हम SOAP :: RPC: ड्राइवर उदाहरण का उपयोग करके निम्नलिखित विधि को कॉल कर सकते हैं।

driver.add_method(name, *paramArg)

यहाँ मापदंडों का वर्णन है -

अनु क्रमांक। पैरामीटर और विवरण
1

name

दूरस्थ वेब सेवा विधि का नाम।

2

paramArg

दूरस्थ प्रक्रियाओं के मापदंडों के नाम निर्दिष्ट करता है।

चरण 3 - SOAP सेवा शुरू करें

अंतिम चरण SOAP :: RPC :: ड्राइवर उदाहरण का उपयोग करके SOAP सेवा को इनवॉइस करना है -

result = driver.serviceMethod(paramArg...)

यहाँ serviceMethod वास्तविक वेब सेवा विधि है और paramArg ... सेवा विधि में पारित करने के लिए आवश्यक सूची पैरामीटर है।

Example

उपरोक्त चरणों के आधार पर, हम एक SOAP क्लाइंट को निम्नानुसार लिखेंगे -

#!/usr/bin/ruby -w

require 'soap/rpc/driver'

NAMESPACE = 'urn:ruby:calculation'
URL = 'http://localhost:8080/'

begin
   driver = SOAP::RPC::Driver.new(URL, NAMESPACE)
   
   # Add remote sevice methods
   driver.add_method('add', 'a', 'b')

   # Call remote service methods
   puts driver.add(20, 30)
rescue => err
   puts err.message
end

आगे की रीडिंग

मैंने आपको रूबी के साथ वेब सेवाओं की बहुत ही मूल अवधारणाओं के बारे में समझाया है। यदि आप इसे और नीचे ड्रिल करना चाहते हैं, तो रूबी के साथ वेब सेवाओं पर अधिक विवरण खोजने के लिए निम्न लिंक है ।