gpt4 book ai didi

ruby-on-rails - POST 方法不适用于 rack-cors rails 4

转载 作者:太空宇宙 更新时间:2023-11-03 16:45:51 24 4
gpt4 key购买 nike

我在我的 Rails 4 应用程序中使用 rack-cors gem,这样我就可以做一个基于 JSON 的 API。我项目中的所有 GET 方法都工作正常,但 POST 方法返回 500 内部服务器错误。

我在我的 application.rb 文件中进行这样的配置:

module Railsapp
class Application < Rails::Application
config.active_record.raise_in_transactional_callbacks = true
config.middleware.insert_before 0, "Rack::Cors" do
allow do
origins '*'
resource '*', :headers => :any, :methods => [:get, :post, :put, :options, :delete]
end
end
end
end

我的 application_controller.rb 文件如下所示:

before_filter :cors_preflight_check
after_filter :cors_set_access_control_headers headers

def cors_set_access_control_headers
headers['Access-Control-Allow-Origin'] = '*'
headers['Access-Control-Allow-Methods'] = 'POST, GET, OPTIONS'
headers['Access-Control-Allow-Headers'] = '*'
headers['Access-Control-Max-Age'] = "1728000"
end

def cors_preflight_check
if request.method == :options
headers['Access-Control-Allow-Origin'] = '*'
headers['Access-Control-Allow-Methods'] = 'POST, GET, OPTIONS'
headers['Access-Control-Allow-Headers'] = '*'
headers['Access-Control-Max-Age'] = '1728000'
render :text => '', :content_type => 'text/plain'
end
end

routes.rb 文件中我添加了这一行

  get '*all' => 'application#cors_preflight_check', :constraints => { :method => 'OPTIONS' }

我已经尝试了大多数 stackoverflow 解决方案,但都没有帮助。谁能帮我解决这个问题。

最佳答案

好的,如果您使用的是 rack-cors gem,则不必在 application_controller 上包含 cors_* 方法,并且路线

application.rb 中的代码就足够了。但是,如果您仍然遇到问题,请尝试查看 gem 的 rails4 应用程序示例项目:https://github.com/cyu/rack-cors/blob/master/examples/rails4/

关于ruby-on-rails - POST 方法不适用于 rack-cors rails 4,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33053167/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com