Ruby on rails Savon OpenSSL::SSL::SSLError
我将ruby 1.8.7与rails 2.3.11、savon 1.1.0、wasabi 2.5.0、httpi 1.1.1和httpclient 2.2.7一起使用 每当我运行脚本时:Ruby on rails Savon OpenSSL::SSL::SSLError,ruby-on-rails,wsdl,openssl,basic-authentication,savon,Ruby On Rails,Wsdl,Openssl,Basic Authentication,Savon,我将ruby 1.8.7与rails 2.3.11、savon 1.1.0、wasabi 2.5.0、httpi 1.1.1和httpclient 2.2.7一起使用 每当我运行脚本时: #!/usr/bin/env ruby require File.expand_path(File.join(File.dirname(__FILE__), '..', 'config', 'environment')) require 'savon' client = Savon::Client.new d
#!/usr/bin/env ruby
require File.expand_path(File.join(File.dirname(__FILE__), '..', 'config', 'environment'))
require 'savon'
client = Savon::Client.new do |wdsl, http|
wdsl.document = 'https://www.atmosfair.de:8443/service/AtmosfairEmissionService3?wsdl'
http.auth.ssl.verify_mode = :none
http.auth.basic "user", "password"
end
client.request :wdsl, "getFlightEmission" do
soap.body = {
:departure => "VIE",
:arrival => "DUB"
}
end
我明白了:
HTTPI使用httpclient适配器执行httpget
/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient/session.rb:300:in
`connect':SSL_connect返回=1 errno=0 state=SSLv2/v3读取服务器
hello A:sslv3警报意外消息(OpenSSL::SSL::SSLError)
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient/session.rb:300:inssl\u connect'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient/session.rb:757:in
connect'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient/timeout.rb:131:intimeout'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient/session.rb:748:in
connect'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient/session.rb:606:inquery'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient/session.rb:161:in
query'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient.rb:1070:indo_get_block'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient.rb:873:in
do_请求'
从/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient.rb:966:inprotect\u keep\u alive\u disconnected'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient.rb:872:in
do_请求'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient.rb:760:inrequest'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpclient-2.2.7/lib/httpclient.rb:663:in
get'
来自/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpi-1.1.1/lib/httpi/adapter/httpclient.rb:24:inget'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpi-1.1.1/lib/httpi/adapter/httpclient.rb:64:in
do\u请求'
来自/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpi-1.1.1/lib/httpi/adapter/httpclient.rb:23:inget'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpi-1.1.1/lib/httpi.rb:86:in
get'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpi-1.1.1/lib/httpi.rb:193:in带_适配器
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/httpi-1.1.1/lib/httpi.rb:84:in
get'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/savon-1.1.0/lib/savon/wasabi/document.rb:34:inresolve\u document'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/savon-1.1.0/lib/savon/wasabi/document.rb:15:in
xml'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/wasabi-2.5.0/lib/wasabi/document.rb:131:inparse'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/wasabi-2.5.0/lib/wasabi/document.rb:118:in
parser'
from/usr/local/rvm/gems/ruby-1.8.7-p370/gems/wasabi-2.5.0/lib/wasabi/document.rb:61:in“soap_actions”
来自script/atmosfair.rb:28
而SoapUI给了我:
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/">
<soapenv:Body>
<ns1:FlightEmission xsi:type="ns1:FlightEmissionData" xmlns:ns1="http://www.atmosfair.de/2009/07/travel" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<CO2>0.19</CO2>
<offset>5.0</offset>
<distance>1733</distance>
<CO2PerPkm>0.0</CO2PerPkm>
<CO2InCriticalAltitudes>0.13</CO2InCriticalAltitudes>
<CO2RFI2>0.32</CO2RFI2>
<CO2RFI27>0.41</CO2RFI27>
<CO2RFI3>0.45</CO2RFI3>
<CO2RFI4>0.59</CO2RFI4>
<keroseneConsumption>0.06</keroseneConsumption>
<keroseneConsumptionInCriticalAltitudes>0.04</keroseneConsumptionInCriticalAltitudes>
<specificFuelConsumptionAverage>4.31</specificFuelConsumptionAverage>
<offsetCO2RFI2>8.0</offsetCO2RFI2>
<offsetCO2RFI27>11.0</offsetCO2RFI27>
<offsetCO2RFI3>11.0</offsetCO2RFI3>
<offsetCO2RFI4>15.0</offsetCO2RFI4>
</ns1:FlightEmission>
</soapenv:Body>
</soapenv:Envelope>
0.19
5
1733
0
0.13
0.32
0.41
0.45
0.59
0.06
0.04
4.31
8
11
11
15
知道我做错了什么吗?我通过使用路缘而不是httpclient解决了这个问题:
#!/usr/bin/env ruby
require File.expand_path(File.join(File.dirname(__FILE__), '..', 'config', 'environment'))
require 'iconv'
require 'curb'
require 'savon'
HTTPI.adapter = :curb
client = Savon::Client.new do |wdsl, http|
http.headers = { "Content-Length" => "0", "Connection" => "Keep-Alive" }
http.auth.basic "user", "password"
wdsl.document = 'https://www.atmosfair.de:8443/services/AtmosfairEmissionService3?wsdl'
end
client.http.auth.ssl.verify_mode = :none
response = client.request :wdsl, "getFlightEmission" do
soap.body = {
:departure => "VIE",
:arrival => "DUB"
}
end
现在一切都好了