我正在尝试将 Rack::Cors 与我的 Rails 4 应用程序一起使用,以便我可以执行基于 JSON 的 API。
CORS 在我的 Gemfile 中是这样的:
gem 'rack-cors', :require => 'rack/cors'
我正在我的 application.rb 文件中进行配置,如下所示:
config.middleware.insert_after Rails::Rack::Logger, Rack::Cors, :debug => true, :logger => Rails.logger do
allow do
origins '*'
resource '/messages*', :headers => :any, :methods => [:post, :options]
end
end
我Rails::Rack::Logger
在尝试获取调试信息后插入。
我正在使用 CURL 来测试它,这是我一直在运行的:
curl --verbose --request OPTIONS http://jasonbutzinfo.herokuapp.com/messages.json --header 'Origin: http://www.jasonbutz.info' --header 'Access-Control-Request-Headers: Origin, Accept, Content-Type' --header 'Access-Control-Request-Method: POST'
当我在本地机器上运行 rails 应用程序时,它可以正常工作。当我点击 Heroku 应用程序时,这是我得到的:
> OPTIONS /messages.json HTTP/1.1
> User-Agent: curl/7.30.0
> Host: jasonbutzinfo.herokuapp.com
> Accept: */*
> Origin: http://www.jasonbutz.info
> Access-Control-Request-Headers: Origin, Accept, Content-Type
> Access-Control-Request-Method: POST
>
* Empty reply from server
* Connection #0 to host jasonbutzinfo.herokuapp.com left intact
curl: (52) Empty reply from server
我确实找到了这个问题(Can't get rack-cors working in rails application),但没有提供任何有用的答案。
更新 2013 年 11 月 13 日 16:40 EST
我一直在尝试对正在发生的事情进行更多调试。我已经修补了一些 Rack::Cors 的方法,看看它们是否在 Heroku 上被调用。我还更改了将 Cors 插入机架中间件堆栈顶部的位置。
通过我的猴子补丁,我在、和方法中放置puts
了语句。和方法都被调用。该方法永远不会被调用。因此,似乎有一些东西在请求到达 cors 中间件之前停止了请求。initialize
call
allow
initialize
allow
call