บริการเว็บด้วย Ruby - SOAP4R

SOAP คืออะไร?

Simple Object Access Protocol (SOAP) เป็นโปรโตคอล RPC ข้ามแพลตฟอร์มและไม่ขึ้นกับภาษาตาม XML และโดยปกติแล้ว (แต่ไม่จำเป็น) HTTP

ใช้ XML เพื่อเข้ารหัสข้อมูลที่ทำให้การเรียกโพรซีเดอร์ระยะไกลและ HTTP เพื่อส่งข้อมูลนั้นข้ามเครือข่ายจากไคลเอนต์ไปยังเซิร์ฟเวอร์และในทางกลับกัน

SOAP มีข้อดีหลายประการเหนือเทคโนโลยีอื่น ๆ เช่น COM, CORBA และอื่น ๆ เช่นค่าใช้จ่ายในการติดตั้งและการดีบักที่ค่อนข้างถูกความสามารถในการขยายและความสะดวกในการใช้งานและการมีอยู่ของการใช้งานหลายภาษาและแพลตฟอร์ม

โปรดดูSOAPแบบง่ายๆของเราเพื่อทำความเข้าใจโดยละเอียด

บทนี้ทำให้คุณคุ้นเคยกับการใช้งาน SOAP สำหรับ Ruby (SOAP4R) นี่เป็นบทช่วยสอนพื้นฐานดังนั้นหากคุณต้องการรายละเอียดที่ลึกซึ้งคุณจะต้องอ้างอิงแหล่งข้อมูลอื่น ๆ

การติดตั้ง SOAP4R

SOAP4R เป็นการใช้งาน SOAP สำหรับ Ruby ที่พัฒนาโดย Hiroshi Nakamura และสามารถดาวน์โหลดได้จาก -

NOTE - อาจมีโอกาสมากที่คุณได้ติดตั้งส่วนประกอบนี้แล้ว

Download SOAP

หากคุณตระหนักถึง gem จากนั้นคุณสามารถใช้คำสั่งต่อไปนี้เพื่อติดตั้ง SOAP4R และแพ็คเกจที่เกี่ยวข้อง

$ gem install soap4r --include-dependencies

ถ้าคุณกำลังทำงานบน Windows, แล้วคุณจะต้องดาวน์โหลดไฟล์บีบอัดจากสถานที่ดังกล่าวข้างต้นและความจำเป็นในการติดตั้งโดยใช้วิธีการติดตั้งมาตรฐานโดยการเรียกใช้install.rb ทับทิม

การเขียนเซิร์ฟเวอร์ SOAP4R

SOAP4R รองรับเซิร์ฟเวอร์สองประเภท -

  • ใช้ CGI / FastCGI (SOAP :: RPC :: CGIStub)
  • แบบสแตนด์อโลน (SOAP :: RPC: StandaloneServer)

บทนี้ให้รายละเอียดเกี่ยวกับการเขียนเซิร์ฟเวอร์แบบสแตนด์อะโลน ขั้นตอนต่อไปนี้เกี่ยวข้องกับการเขียนเซิร์ฟเวอร์ SOAP

ขั้นตอนที่ 1 - รับช่วง SOAP :: RPC :: StandaloneServer Class

ในการใช้งานเซิร์ฟเวอร์แบบสแตนด์อโลนของคุณเองคุณต้องเขียนคลาสใหม่ซึ่งจะเป็นลูกของSOAP :: StandaloneServerดังนี้ -

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

NOTE- หากคุณต้องการเขียนเซิร์ฟเวอร์ที่ใช้ FastCGI คุณต้องใช้SOAP :: RPC :: CGIStubเป็นคลาสหลักขั้นตอนที่เหลือจะยังคงเหมือนเดิม

ขั้นตอนที่ 2 - กำหนดวิธีการจัดการ

ขั้นตอนที่สองคือการเขียนวิธีการบริการบนเว็บของคุณซึ่งคุณต้องการเปิดเผยต่อโลกภายนอก

สามารถเขียนเป็นวิธี Ruby แบบธรรมดา ตัวอย่างเช่นลองเขียนสองวิธีเพื่อเพิ่มจำนวนสองจำนวนและหารสองจำนวน -

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 คุณสามารถกำหนดวิธีการบริการในระดับเดียวกับวิธีการ methodDef พารามิเตอร์นี้เป็นตัวเอง

2

methodName

ชื่อของเมธอดที่ถูกเรียกเนื่องจากการร้องขอ RPC

3

paramArg

ระบุชื่อพารามิเตอร์และโหมดพารามิเตอร์เมื่อกำหนด

เพื่อให้เข้าใจถึงการใช้งานของInOutหรือออกพารามิเตอร์พิจารณาวิธีการบริการต่อไปนี้ที่จะใช้เวลาสองพารามิเตอร์ (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

ที่นี่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

เมื่อดำเนินการแอ็พพลิเคชันเซิร์ฟเวอร์นี้จะเริ่มเซิร์ฟเวอร์ SOAP แบบสแตนด์อโลนบนlocalhostและรับฟังคำร้องขอบนพอร์ต 8080 โดยจะแสดงวิธีการบริการหนึ่งวิธีการเพิ่มและdivซึ่งรับสองพารามิเตอร์และส่งคืนผลลัพธ์

ตอนนี้คุณสามารถเรียกใช้เซิร์ฟเวอร์นี้ในพื้นหลังได้ดังนี้ -

$ ruby MyServer.rb&

การเขียนไคลเอนต์ SOAP4R

SOAP :: RPC :: ขับรถระดับให้การสนับสนุนสำหรับการใช้งานของลูกค้าเขียนสบู่ บทนี้อธิบายคลาสนี้และสาธิตการใช้งานบนพื้นฐานของแอพพลิเคชั่น

ต่อไปนี้เป็นข้อมูลขั้นต่ำที่คุณต้องเรียกใช้บริการ SOAP -

  • URL ของบริการ SOAP (SOAP Endpoint URL)
  • เนมสเปซของเมธอดบริการ (Method Namespace URI)
  • ชื่อของวิธีการบริการและพารามิเตอร์

ตอนนี้เราจะเขียนเป็นลูกค้า SOAP ซึ่งจะเรียกวิธีการบริการที่กำหนดไว้ในตัวอย่างข้างต้นชื่อเพิ่มและdiv

ขั้นตอนหลักในการสร้างไคลเอนต์ SOAP มีดังนี้

ขั้นตอนที่ 1 - สร้างอินสแตนซ์ไดร์เวอร์ SOAP

เราสร้างอินสแตนซ์ของSOAP :: RPC :: Driverโดยเรียกวิธีการใหม่ดังนี้ -

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

นี่คือคำอธิบายของพารามิเตอร์ที่ต้องการ -

ซีเนียร์ พารามิเตอร์และคำอธิบาย
1

endPoint

URL ของเซิร์ฟเวอร์ SOAP ที่จะเชื่อมต่อ

2

nameSpace

เนมสเปซที่จะใช้สำหรับ RPC ทั้งหมดที่ทำกับอ็อบเจ็กต์ SOAP :: RPC :: Driver

3

soapAction

ค่าสำหรับฟิลด์ SOAPAction ของส่วนหัว HTTP หากไม่มีค่าเริ่มต้นนี้เป็นสตริงว่าง ""

ขั้นตอนที่ 2 - เพิ่มวิธีการบริการ

ในการเพิ่มวิธีการบริการ SOAP ลงในSOAP :: RPC :: Driverเราสามารถเรียกวิธีการต่อไปนี้โดยใช้SOAP :: RPC ::อินสแตนซ์ไดรเวอร์ -

driver.add_method(name, *paramArg)

นี่คือคำอธิบายของพารามิเตอร์ -

ซีเนียร์ พารามิเตอร์และคำอธิบาย
1

name

ชื่อของวิธีการบริการเว็บระยะไกล

2

paramArg

ระบุชื่อของพารามิเตอร์รีโมตโพรซีเดอร์

ขั้นตอนที่ 3 - เรียกใช้บริการ SOAP

ขั้นตอนสุดท้ายคือการออกใบแจ้งหนี้บริการSOAPโดยใช้SOAP :: RPC ::อินสแตนซ์ไดรเวอร์ดังต่อไปนี้ -

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

อ่านเพิ่มเติม

ฉันได้อธิบายแนวคิดพื้นฐานของ Web Services with Ruby ให้คุณแล้ว หากคุณต้องการที่จะเจาะลึกลงไปมันต่อไปแล้วมีการเชื่อมโยงเพื่อหารายละเอียดเพิ่มเติมเกี่ยวกับการต่อไปWeb Services กับทับทิม