我正在尝试在我的 rails 应用程序中实现 google places api。
这是我在尝试使用从 ajax 请求中获取数据的函数时遇到的错误:
XMLHttpRequest cannot load . Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:3000' is therefore not allowed access.
我正在使用 rack-cors gem,并将此代码段添加到我的 config/application.rb 文件中:
config.middleware.insert_before 0, "Rack::Cors" do
allow do
origins '*'
resource '*', :headers => :any, :methods => [:get, :post, :options]
end
end
这是我认为的 ajax 请求(coffeescript):
$.ajax
url: url
dataType: "json"
type: "GET"
我已将此部分添加到我的 application_controller
before_filter :cors_preflight_check
after_filter :cors_set_access_control_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
这个,到我的路线文件
match '*path' => 'application#cors_preflight_check', :via => :options
我注意到“cors_preflight_check”方法不是由我的请求触发的。(当我单击视图中的某个链接时,我会发出 AJAX 请求)
而且我注意到我的请求标头保持不变。
(Access-Control-Allow-Origin 未添加到请求标头中)
jsonp 不是一个选项,因为 places api 不支持它
尝试了在这些线程中编写的所有内容:
- https://github.com/cyu/rack-cors/issues/33
- 无法让 rack-cors 在 rails 应用程序中工作(config.middleware.insert 0,Rack::Cors 可以)
- https://demisx.github.io/rails-api/2014/02/18/configure-accept-headers-cors.html
- POST 方法在 rack-cors rails 4 中不起作用(在应用程序控制器中添加之前和之后的操作)
- 使用 Rack-cors 和 Grape 添加自定义响应标头(使用 :expose 键)