OpenSSL在Ruby 1.9.3中遇到麻烦

我在Ubuntu 12.04上遇到了OpenSSL 1.0.1 + Ruby 1.9.3的半严重问题。

所有ruby都安装了rvm

require 'uri' require 'net/http' require 'net/https' endpoint = "https://secure.mmoagateway.com/api/transact.php" RUBY_184_POST_HEADERS = { "Content-Type" => "application/x-www-form-urlencoded" } body = "orderid=ae5dd847d9f31209cbffeeea076ed966&orderdescription=Active+Merchant+Remote+Test+Purchase&ccnumber=4111111111111111&ccexp=0913&cvv=123&company=Widgets+Inc&address1=1234+My+Street&address2=Apt+1&city=Ottawa&state=ON&zip=K1C2N6&country=CA&phone=%28555%29555-5555&firstname=&lastname=&email=&amount=1.00&type=auth&username=demo&password=password" headers = {} endpoint = endpoint.is_a?(URI) ? endpoint : URI.parse(endpoint) http = Net::HTTP.new(endpoint.host, endpoint.port) http.use_ssl = true http.verify_mode = OpenSSL::SSL::VERIFY_NONE http.set_debug_output(STDOUT) result = http.post(endpoint.request_uri, body, RUBY_184_POST_HEADERS.merge(headers)) puts(result) 

在Ubuntu 12.04 + Ruby 1.9.3 + Openss 1.0.1上我得到以下输出:

 % ruby test.rb opening connection to secure.mmoagateway.com... opened Conn close because of connect error Connection reset by peer - SSL_connect /usr/lib/ruby/1.9.1/net/http.rb:799:in `connect': Connection reset by peer - SSL_connect (Errno::ECONNRESET) from /usr/lib/ruby/1.9.1/net/http.rb:799:in `block in connect' from /usr/lib/ruby/1.9.1/timeout.rb:54:in `timeout' from /usr/lib/ruby/1.9.1/timeout.rb:99:in `timeout' from /usr/lib/ruby/1.9.1/net/http.rb:799:in `connect' from /usr/lib/ruby/1.9.1/net/http.rb:755:in `do_start' from /usr/lib/ruby/1.9.1/net/http.rb:744:in `start' from /usr/lib/ruby/1.9.1/net/http.rb:1284:in `request' from /usr/lib/ruby/1.9.1/net/http.rb:1307:in `send_entity' from /usr/lib/ruby/1.9.1/net/http.rb:1096:in `post' from test.rb:17:in `' 

使用Ruby 1.8.7,我得到了正确的输出:

 $ ruby test.rb opening connection to secure.mmoagateway.com... opened <- "POST /api/transact.php HTTP/1.1\r\nAccept: */*\r\nContent-Type: application/x-www-form-urlencoded\r\nConnection: close\r\nContent-Length: 347\r\nHost: secure.mmoagateway.com\r\n\r\n"  "HTTP/1.1 200 OK\r\n" -> "Date: Wed, 04 Jul 2012 01:26:35 GMT\r\n" -> "Server: Apache\r\n" -> "Content-Length: 240\r\n" -> "Connection: close\r\n" -> "Content-Type: text/html\r\n" -> "\r\n" reading 240 bytes... -> "response=1&responsetext=SUCCESS&authcode=123456&transactionid=1648894346&avsresponse=N&cvvresponse=N&orderid=ae5dd847d9f31209cbffeeea076ed966&type=auth&response_code=100&merchant_defined_field_6=&merchant_defined_field_7=&customer_vault_id=" read 240 bytes Conn close # response=1&responsetext=SUCCESS&authcode=123456&transactionid=1648894346&avsresponse=N&cvvresponse=N&orderid=ae5dd847d9f31209cbffeeea076ed966&type=auth&response_code=100&merchant_defined_field_6=&merchant_defined_field_7=&customer_vault_id= 

我在1.9.3和1.0.1的arch中遇到了同样的问题。

如果我在我的12.04系统上从oneiric安装1.0.0e它也适用于ruby 1.9.3

我想这可能与ubuntu bug有关: https : //bugs.launchpad.net/ubuntu/+source/openssl/+bug/965371

虽然我从Debian下载了软件包,但是他们说这些软件包已经修复并且没有运气。

有没有其他人遇到过类似的问题?

我在连接到授权网关时遇到了同样的问题。 最后,我能够通过强制sslv3连接

 http = Net::HTTP.new(uri.host, uri.port) http.use_ssl = true if @is_https http.verify_mode = OpenSSL::SSL::VERIFY_NONE if @is_https http.ssl_version = :SSLv3 

我有同样的问题… 这里是信息, rvm pkg install opensslrvm reinstall 1.9.3-p194 --with-openssl-dir=~/.rvm/usr解决了这个问题,但它对我没有帮助