Настройте WEBrick для использования автоматически сгенерированного самоподписанного сертификата SSL / HTTPS

Я хочу разработать свое приложение Ruby on Rails локально с помощью SSL / HTTPS, но у меня возникают проблемы с настройкой сервера для использования SSL. Вот то, что я уже пробовал:

rails server [options]

Команда rails server не имеет опции ssl (rails server --help):

Usage: rails server [mongrel, thin, etc] [options]
  -p, --port=port         Runs Rails on the specified port.
                          Default: 3000
  -b, --binding=ip        Binds Rails to the specified ip.
                          Default: 0.0.0.0
  -c, --config=file       Use custom rackup configuration file
  -d, --daemon            Make server run as a Daemon.
  -u, --debugger          Enable the debugger
  -e, --environment=name  Specifies the environment to run this server under
                          (test/development/production).
                          Default: development
                          
  -P, --pid=pid           Specifies the PID file.
                          Default: tmp/pids/server.pid

  -h, --help              Show this help message.

Пользовательский экземпляр WEBrick с автоматически созданным самоподписанным SSL-сертификатом

Мой код

Следуя WEBrick документации для HTTPS, я создал следующий сценарий Ruby, который я запускаю как ruby server.rb:

require 'webrick'
include WEBrick

root = File.expand_path './public'

cert_name = [
  %w[CN localhost],
]

server = HTTPServer.new(
  :BindAddress => '127.0.0.1',
  :Port => '4430',
  :DocumentRoot => root,
  :SSLEnable => true,
  :SSLCertName => cert_name # LOOK! SSLCertName IS SET!
)

# Shutdown gracefully on signal interrupt CTRL-C
# http://www.ruby-doc.org/core-2.1.1/Kernel.html#method-i-trap
trap('INT') { server.shutdown }

server.start

Согласно документации, на которую я ссылался выше:

Это запустит сервер с самозаверяющим сертификатом.

и согласно документации для WEBrick :: Config < / а>,

WEBrick может автоматически создать самозаверяющий сертификат, если установлено: SSLCertName.

Ошибки

Когда я запускаю сервер, я получаю следующий результат:

INFO  WEBrick 1.3.1
INFO  ruby 2.1.1 (2014-02-24) [x86_64-darwin13.0]
INFO  WEBrick::HTTPServer#start: pid=26059 port=4430

Однако когда я пытаюсь получить доступ к https://localhost:4430/robots.txt, я получаю следующую ошибку в Chrome 33.0.1750.117:

введите описание изображения здесь

и следующая ошибка, когда я пытаюсь использовать тот же URL-адрес в Firefox 27.0.1:

введите описание изображения здесь

Я нашел ошибку ssl_error_rx_record_too_long, и она выглядит как будто это может быть вызвано несколькими разными вещами. Возможно, WEBrick все еще прослушивает HTTP-запросы на порту 80, но это кажется странным, учитывая, что я явно включил SSL на порт 4430.

Журналы доступа

Кроме того, вот содержимое журнала доступа из WEBrick, когда я делаю запрос на https://localhost:4430/robots.txt из Chrome, но я понятия не имею, что это означает (похоже, он закодирован в шестнадцатеричном формате или что-то в этом роде):

ERROR bad Request-Line `\x16\x03\x01\x02\x00\x01\x00\x01ü\x03\x03S\x15ußð'¦\x14·áÚOá,j\x7FÅ=üüNn#\x02ëý\x0Fø‚\x00\x00(À+À/\x00žÌ\x14Ì\x13\x00œÀ'.
localhost - - [04/Mar/2014:01:42:39 EST] "\x16\x03\x01\x02\x00\x01\x00\x01ü\x03\x03S\x15ußð'¦\x14·áÚOá,j\x7FÅ=üüNn#\x02ëý\x0Fø‚\x00\x00(À+À/\x00žÌ\x14Ì\x13\x00œÀ" 400 417
- -> 
ERROR bad Request-Line `\x16\x03\x01\x02\x00\x01\x00\x01ü\x03\x02S\x15ußj\x05ç©!€¿'ÄÃåë!t…ß\x06pDÒÒ4?”»7\x19\x00\x00\x1EV\x00À'.
localhost - - [04/Mar/2014:01:42:39 EST] "\x16\x03\x01\x02\x00\x01\x00\x01ü\x03\x02S\x15ußj\x05ç©!€¿'ÄÃåë!t…ß\x06pDÒÒ4?”»7\x19\x00\x00\x1EV\x00À" 400 398
- -> 
ERROR bad Request-Line `\x16\x03\x01\x02\x00\x01\x00\x01ü\x03\x01S\x15ußñom¾u<n¨ý9yö“¤Øcƒ{½wh)M@š1;\x00\x00\x1EV\x00À'.
localhost - - [04/Mar/2014:01:42:39 EST] "\x16\x03\x01\x02\x00\x01\x00\x01ü\x03\x01S\x15ußñom¾u<n¨ý9yö“¤Øcƒ{½wh)M@š1;\x00\x00\x1EV\x00À" 400 392
- -> 
ERROR bad URI `\x04ËB¿É\\ ˆ2ðiwñ·*\x02\x06^´\x00@v\x00\x00\x14\x00ÿV\x00\x009\x005\x003\x002\x00\x05\x00\x04\x00/\x00'.
localhost - - [04/Mar/2014:01:42:39 EST] "\x16\x03\x00\x00?\x01\x00\x00;\x03\x00S\x15uß…N®ˆ\r\x04ËB¿É\\ ˆ2ðiwñ·*\x02\x06^´\x00@v\x00\x00\x14\x00ÿV\x00\x009\x005\x003\x002\x00\x05\x00\x04\x00/\x00" 400 389
- -> \x04ËB¿É\\ ˆ2ðiwñ·*\x02\x06^´\x00@v\x00\x00\x14\x00ÿV\x00\x009\x005\x003\x002\x00\x05\x00\x04\x00/\x00

Источник Ruby для модуля SSL

Кроме того, я проверил исходный код Ruby для SSL. module, но я не вижу там ничего очевидного, почему это может не работать:

def setup_ssl_context(config) # :nodoc:
  unless config[:SSLCertificate]
    cn = config[:SSLCertName]
    comment = config[:SSLCertComment]
    cert, key = Utils::create_self_signed_cert(1024, cn, comment) # LOOK HERE!
    config[:SSLCertificate] = cert
    config[:SSLPrivateKey] = key
  end
  # etc...
end

# Higher up in the file...
def create_self_signed_cert(bits, cn, comment)
  # etc ...
  cert = OpenSSL::X509::Certificate.new
  cert.version = 2
  cert.serial = 1
  name = OpenSSL::X509::Name.new(cn)
  cert.subject = name
  cert.issuer = name
  # etc ...
end

Моя среда

Вот следующие вещи, которые я использую для разработки:

  1. OS X Mavericks.
  2. Рубин 2.1.1.
  3. Рельсы 4.0.3.

Резюме

Вот где я сейчас нахожусь, и я не уверен, что делать дальше. Я знаю, что могу просто передать свой собственный файл самозаверяющего сертификата (сгенерированный с помощью чего-то вроде OpenSSL) в WEBrick, но в документации говорится, что WEBrick может автоматически сгенерировать свой собственный, и я действительно заинтересован в том, чтобы это работало.

Я также знаю, что могу использовать другой веб-сервер, например Thin с его опцией --ssl, но опять же, я хотел использовать WEBrick, поскольку это готовый веб-сервер для Rails, я хочу иметь возможность легко и быстро настроить веб-сервер SSL для разработки без необходимости загружать дополнительные драгоценные камни и тому подобное.

Мне также известно, что существует это решение. , но опять же, я заинтересован в том, чтобы WEBrick автоматически генерировал свой собственный сертификат (и, кроме того, это решение кажется немного слишком сложным для того, что я пытаюсь сделать).

Есть ли у кого-нибудь идеи, что может быть не так?


person Community    schedule 04.03.2014    source источник


Ответы (1)


Хорошо, я понял, в чем дело, мне следовало обратить более пристальное внимание на инструкции для HTTPS в WEBrick, это точный код из примера:

require 'webrick'
require 'webrick/https' # SEE THIS?

cert_name = [
  %w[CN localhost],
]

server = WEBrick::HTTPServer.new(:Port => 8000,
                                 :SSLEnable => true,
                                 :SSLCertName => cert_name)

Видите строку, в которой написано require 'webrick/https'? В моей исходной конфигурации этого не было. Я не думал, что он мне понадобится.

Как только я добавил его, мой скрипт начал работать по HTTPS, и я наконец смог подключиться к https://localhost:4430/robots.txt. ‹Face-palm›

person Community    schedule 04.03.2014
comment
Если я следую примеру Sinatra, он просто копируется в app.rb? Или мне создать server.rb, который загружает app.rb? - person coolaj86; 18.02.2015
comment
В последних версиях OpenSSL SSLCertName необходимо указывать следующим образом: [['CN', 'localhost', OpenSSL::ASN1::PRINTABLESTRING]] - person Tobias Cohen; 19.06.2015
comment
@cupcake, можете ли вы написать руководство о том, как сделать рельсы localhost на https? - person user1735921; 15.09.2015
comment
@ user1735921, к сожалению, у меня нет на это времени. Не только это, но, вероятно, это неправильный способ реализации https в приложении Rails (локально или в производственной среде). - person ; 15.09.2015
comment
@ user1735921, возможно, вы захотите проверить этот другой ответ если вы все еще ищете. - person jcaudle; 14.02.2017