Force SSL for specific routes in Rails 3.1

a 夏天 提交于 2019-12-05 15:37:25

问题


I need to force SSL on all routes in my application except for landing#index.

In config/application.rb, I have:

config.force_ssl = true

Then in landing_controller.rb, I have:

force_ssl :except => :index

However, all routes are still being redirected to https.

Does anyone know how to conditionally force SSL in a Rails 3.1+ application?

Solution:

Add the following to your Gemfile:

gem 'rack-ssl-enforcer'

Add the following to your config/application.rb:

config.middleware.use Rack::SslEnforcer, :except => [ /\/$/ ], :strict => true

回答1:


I asked a similar question on stackoverflow here and was told to use https://github.com/tobmatth/rack-ssl-enforcer. I haven't tried it out yet, but based on the readme, it appears to solve your problem of conditionally enforcing ssl on certain routes.




回答2:


Rails 4 with ActiveAdmin 1.0b, I modified config/initializers/active_admin.rb:

config.before_filter :force_ssl_redirect, if: :https_enabled?

force_ssl_redirect is defined in actionpack/lib/action_controller/metal/force_ssl.rb and is what Rails' force_ssl class method calls.

https_enabled? defined in my application_controller.rb:

def https_enabled?
  ENV['HTTPS_ENABLED'] == 'true'
end



回答3:


You can do it this way:

controller

force_ssl :except => :index

view

supposing your index path name is index_landing_path

<%= link_to 'Landing', index_landing_path, :protocol => 'http' %>


来源:https://stackoverflow.com/questions/10605407/force-ssl-for-specific-routes-in-rails-3-1

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!