ruby - 尝试通过 https 发出发布请求时获取 OpenSSL::SSL::SSLError: SSL_set_tlsext_host_name

标签 ruby rest ssl openssl net-http

我正在尝试使用 ruby​​ 中的 net/http 类通过 https 发送发布请求,但出现此错误:

 OpenSSL::SSL::SSLError: SSL_set_tlsext_host_name
        from C:/RailsInstaller/Ruby2.1.0/lib/ruby/2.1.0/net/http.rb:920:in `connect'
        from C:/RailsInstaller/Ruby2.1.0/lib/ruby/2.1.0/net/http.rb:920:in `block in connect'
        from C:/RailsInstaller/Ruby2.1.0/lib/ruby/2.1.0/timeout.rb:76:in `timeout'
        from C:/RailsInstaller/Ruby2.1.0/lib/ruby/2.1.0/net/http.rb:920:in `connect'
        from C:/RailsInstaller/Ruby2.1.0/lib/ruby/2.1.0/net/http.rb:863:in `do_start'
        from C:/RailsInstaller/Ruby2.1.0/lib/ruby/2.1.0/net/http.rb:852:in `start'
        from C:/RailsInstaller/Ruby2.1.0/lib/ruby/2.1.0/net/http.rb:1369:in `request'

这是我正在使用的代码示例:

uri = URI.parse('https://somehost/1')
proxy = "proxy-chain.domain.com"
port = 911
http = Net::HTTP.new(uri.host, uri.port, proxy, port)
http.use_ssl = true
http.ssl_version = 'SSLv2'
http.ciphers = OpenSSL::Cipher.ciphers      
req = Net::HTTP::Post.new(uri.request_uri)
req.set_form_data(JSON.parse(some_jsonstring_data))
res = http.request(req)

更多信息:

我知道我要攻击的主机使用 TLS1.2

我尝试按照下面@jww 的回答中的建议设置 ssl_options,但没有成功...如果我不设置 ssl_version,我会收到此错误:

OpenSSL::SSL::SSLError: SSL_connect SYSCALL returned=5 errno=0 state=SSLv2/v3 read server hello A

非常欢迎任何帮助。谢谢大家!!

最佳答案

http.ssl_version = 'SSLv2'

Server Name Indication ,或 SNI,是 TLS 扩展。扩展在 TLS 1.0 之前不可用。

而且 SSLv2 是不安全的。您可能应该在 2015 年避免使用它(和 SSLv3)。另请参阅 How to set TLS context options in Ruby (like OpenSSL::SSL::SSL_OP_NO_SSLv2) .

关于ruby - 尝试通过 https 发出发布请求时获取 OpenSSL::SSL::SSLError: SSL_set_tlsext_host_name,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31574447/

相关文章:

ssl - 如何验证 WebSphere MQ 是否使用 SSL?

ruby-on-rails - Rails 连接模型困惑(连接许多表)

ruby - 如何使用 Ruby 将键盘和鼠标命令发送到底层操作系统?

ruby - 基于目录和文件的静态站点生成器

django - Restangular、Django REST 和关系

rest - 400 与 422 对数据 POST 的响应

java - Spring应用程序中的NoSuchBeanDefinitionException

ruby-on-rails - 将记录行返回到查看页面时 ActiveRecord 模型的奇怪行为

.net - 禁止使用 TLS session 票证

ssl - PFSense OpenVPN TLS 握手失败