回答:
組み込みsoap/wsdlDriver
クラスを使用しました。実際にはSOAP4Rです。犬は遅いですが、本当にシンプルです。gems / etcから取得するSOAP4Rは、同じものの更新バージョンにすぎません。
コード例:
require 'soap/wsdlDriver'
client = SOAP::WSDLDriverFactory.new( 'http://example.com/service.wsdl' ).create_rpc_driver
result = client.doStuff();
それだけです
私は、Rubyを介してSOAP Webサービスと簡単にやり取りできるようにSavonを作成しました。
ぜひチェックしてみてください。
ハンドソープからサボンに切り替えました。
ここにあるブログの記事のシリーズの 2つのクライアントライブラリを比較するには。
試してみてくださいSOAP4Rを
そして私はちょうどこれについてRails Envy Podcast(ep 31)で聞いた:
ケントSibilev Datanoiseはまた、Railsの2.1(以上)へのRails ActionWebServiceライブラリを移植していました。これにより、独自のRubyベースのSOAPサービスを公開できます。彼は、ブラウザを使用してサービスをテストできるscaffold / testモードも備えています。
受け入れテストのために偽のSOAPサーバーを作成する必要があったとき、私はRubyでSOAPを使用しました。これが問題に対処するための最良の方法であったかどうかはわかりませんが、私にとってはうまくいきました。
私はサーバーにSinatra gem(ここでSinatraを使用してモックエンドポイントを作成することについて書きました)を使用し、XMLのものにはNokogiriを使用しました(SOAPはXMLで動作しています)。
そのため、最初に2つのファイル(config.rbとresponse.rbなど)を作成し、その中にSOAPサーバーが返す定義済みの回答を入れました。でconfig.rb私は、WSDLファイルを置くが、文字列としています。
@@wsdl = '<wsdl:definitions name="StockQuote"
targetNamespace="http://example.com/stockquote.wsdl"
xmlns:tns="http://example.com/stockquote.wsdl"
xmlns:xsd1="http://example.com/stockquote.xsd"
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
xmlns="http://schemas.xmlsoap.org/wsdl/">
.......
</wsdl:definitions>'
でresponses.rb私は、SOAPサーバは、異なるシナリオのために返すことを応答のためのサンプルを入れています。
@@login_failure = "<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body>
<LoginResponse xmlns="http://tempuri.org/">
<LoginResult xmlns:a="http://schemas.datacontract.org/2004/07/WEBMethodsObjects" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<a:Error>Invalid username and password</a:Error>
<a:ObjectInformation i:nil="true"/>
<a:Response>false</a:Response>
</LoginResult>
</LoginResponse>
</s:Body>
</s:Envelope>"
それでは、実際にサーバーを作成した方法を紹介しましょう。
require 'sinatra'
require 'json'
require 'nokogiri'
require_relative 'config/config.rb'
require_relative 'config/responses.rb'
after do
# cors
headers({
"Access-Control-Allow-Origin" => "*",
"Access-Control-Allow-Methods" => "POST",
"Access-Control-Allow-Headers" => "content-type",
})
# json
content_type :json
end
#when accessing the /HaWebMethods route the server will return either the WSDL file, either and XSD (I don't know exactly how to explain this but it is a WSDL dependency)
get "/HAWebMethods/" do
case request.query_string
when 'xsd=xsd0'
status 200
body = @@xsd0
when 'wsdl'
status 200
body = @@wsdl
end
end
post '/HAWebMethods/soap' do
request_payload = request.body.read
request_payload = Nokogiri::XML request_payload
request_payload.remove_namespaces!
if request_payload.css('Body').text != ''
if request_payload.css('Login').text != ''
if request_payload.css('email').text == some username && request_payload.css('password').text == some password
status 200
body = @@login_success
else
status 200
body = @@login_failure
end
end
end
end
これがお役に立てば幸いです。
私は同じ問題を抱えていて、Savonに切り替えてから、開いているWSDL(http://www.webservicex.net/geoipservice.asmx?WSDLを使用しました)でそれをテストしただけで、これまでのところ良好です。
以下のようなHTTP呼び出しを使用してSOAPメソッドを呼び出しましたが、
require 'net/http'
class MyHelper
def initialize(server, port, username, password)
@server = server
@port = port
@username = username
@password = password
puts "Initialised My Helper using #{@server}:#{@port} username=#{@username}"
end
def post_job(job_name)
puts "Posting job #{job_name} to update order service"
job_xml ="<soapenv:Envelope xmlns:soapenv=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:ns=\"http://test.com/Test/CreateUpdateOrders/1.0\">
<soapenv:Header/>
<soapenv:Body>
<ns:CreateTestUpdateOrdersReq>
<ContractGroup>ITE2</ContractGroup>
<ProductID>topo</ProductID>
<PublicationReference>#{job_name}</PublicationReference>
</ns:CreateTestUpdateOrdersReq>
</soapenv:Body>
</soapenv:Envelope>"
@http = Net::HTTP.new(@server, @port)
puts "server: " + @server + "port : " + @port
request = Net::HTTP::Post.new(('/XISOAPAdapter/MessageServlet?/Test/CreateUpdateOrders/1.0'), initheader = {'Content-Type' => 'text/xml'})
request.basic_auth(@username, @password)
request.body = job_xml
response = @http.request(request)
puts "request was made to server " + @server
validate_response(response, "post_job_to_pega_updateorder job", '200')
end
private
def validate_response(response, operation, required_code)
if response.code != required_code
raise "#{operation} operation failed. Response was [#{response.inspect} #{response.to_hash.inspect} #{response.body}]"
end
end
end
/*
test = MyHelper.new("mysvr.test.test.com","8102","myusername","mypassword")
test.post_job("test_201601281419")
*/
それが役に立てば幸い。乾杯。