Использовать SSL с помощью ssl_requirement в приложении Rails 2

У меня есть приложение Rails, которое нужно запускать под SSL. Я попробовал ssl_requirement, но мне кажется, что я должен вводить все действия в каждом controllerе.

Есть ли какой-нибудь метод, который я могу добавить перед_фильтром в controller приложения с помощью ssl_requirement, чтобы приложения автоматически перенаправлялись на https, когда пользовательский запрос находится в http?

Спасибо всем. 🙂

Используйте промежуточное ПО Rack .

# lib/force_ssl.rb class ForceSSL def initialize(app) @app = app end def call(env) if env['HTTPS'] == 'on' || env['HTTP_X_FORWARDED_PROTO'] == 'https' @app.call(env) else req = Rack::Request.new(env) [301, { "Location" => req.url.gsub(/^http:/, "https:") }, []] end end end # config/environment.rb config.middleware.use "ForceSSL" 

Вы можете попробовать выполнить тест, если запрос находится в ssl или нет в файле before_filter в вашем приложении

 class Application < AC::Base before_filter :need_ssl def need_ssl redirect_to "https://#{request.host}/#{request.query_string}" unless request.ssl? end end 

Основная проблема заключается в том, что force_ssl.rb не загружается и что lib не загружается по умолчанию в rails 3.1. Вы должны добавить

 config.autoload_paths += %W(#{config.root}/lib) config.autoload_paths += Dir["#{config.root}/lib/**/"] 

к application.rb

  • Как указать список шифров SSL / TLS, предлагаемый конкретным сайтом?
  • Как переопределить шифрованный список, отправленный на сервер Android при использовании HttpsURLConnection?
  • Доверяйте всем сертификатам, используя HttpClient over HTTPS
  • Сертификаты клиента Java через HTTPS / SSL
  • Использование SSL и SslStream для одноранговой аутентификации?
  • Как сделать Java 6, которая не работает с SSL-соединением с неправильным отключением SSL-партнера, как Java 7?
  • Как получить файл .pem из .key и .crt файлов?
  • Trust Anchor не найден для подключения SSL для Android
  • Создание libcurl с поддержкой SSL в Windows
  • Android HttpClient и HTTPS
  • curl: (60) SSL-сертификат: не удалось получить сертификат локального эмитента
  • Давайте будем гением компьютера.