ruby-on-rails – 如何防止force_ssl在重定向中破坏params?

ruby-on-rails – 如何防止force_ssl在重定向中破坏params?,第1张

概述我有以下路线: resources :widgets do resources :ordersend 所以请求,例如to / widgets / 1 / orders / new转到OrderController,它可以访问params [:widget_id]以了解正在购买的小部件. 问题是:我在OrderController中使用force_ssl.这导致请求: http://www.e 我有以下路线:

resources :Widgets do  resources :ordersend

所以请求,例如to / Widgets / 1 / orders / new转到OrderController,它可以访问params [:Widget_ID]以了解正在购买的小部件.

问题是:我在OrderController中使用force_ssl.这导致请求:

http://www.example.com/Widgets/1/orders/new

被重定向(302)到:

https://www.example.com/

换句话说,force_ssl正在执行其工作(重定向到URL的https协议版本),但正在销毁流程中路由的动态段指定的参数.我怎样才能防止这种情况发生(更可取)或以最不具攻击性的方式解决这个问题?

请注意,这是在Heroku上托管的,例如Apache重定向对我不起作用.

解决方法 我相信force_ssl的默认行为是将参数从非安全连接传递到安全连接.如果这不是您想要的行为,您可以尝试通过添加如下的初始化程序来覆盖force_ssl函数:

## Pass parameters in SSL redirects#module ActionController  module ForceSSL    module ClassMethods      def force_ssl(options = {})        host = options.delete(:host)        before_filter(options) do          if !request.ssl? && !Rails.env.development?            secure_params = request.params.clone            [:only,:except,:protocol,:status,:host].each {|s| secure_params.delete(s)}            redirect_options = {:protocol => 'https://',:status => :moved_permanently}            redirect_options.merge!(:host => host) if host            redirect_to redirect_options.merge(secure_params)          end        end      end    end  endend
总结

以上是内存溢出为你收集整理的ruby-on-rails – 如何防止force_ssl在重定向中破坏params?全部内容,希望文章能够帮你解决ruby-on-rails – 如何防止force_ssl在重定向中破坏params?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1273761.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存