บริการเว็บด้วย 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 กับทับทิม