Рассмотрим следующий код:
require 'net/https'
uri = URI.parse("https://host/index.html")
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = true
http.verify_mode = OpenSSL::SSL::VERIFY_NONE
request = Net::HTTP::Get.new(uri.path)
response = http.request(request)
где https://host/index.html
- действительный адрес с недействительным сертификатом на сервере.
На старых версиях ruby (в частности, 1.8.7-p334 и 1.9.2-p180) этот код работает нормально. Во всех последних версиях (1.8.7-p352, 1.9.2-p290 и 1.9.3-p0) выдается следующее исключение:
OpenSSL::SSL::SSLError: SSL_connect SYSCALL returned=5 errno=0 state=unknown state
в последней строке.
Изменение verify_mode на OpenSSL::SSL::VERIFY_PEER
дает именно ошибку, предполагающую, что он пытается проверить сертификат, несмотря на настройку.
Как мне убедить ruby проигнорировать неверный сертификат и подключиться?