我正在构建一个基于 Backbone.js 的应用程序并面临一个奇怪的问题。
在某个时候,该应用程序请求一个集合资源,并且在 Chrome(和 Safari)中我收到这样的错误:
XMLHttpRequest cannot load http://api.mydomain.net/v1/foos/00000d/bars/000014/boots Origin http://localhost:3501 is not allowed by Access-Control-Allow-Origin.
好的,我认为 CORS 问题并归咎于我的 API。然后通过 CURL 请求这个资源:
curl -i -H'Accept: application/json' -H'X-Auth-Token: pAWp5hrCmXA83GgFzgHC' -XOPTIONS 'http://api.mydomain.net/v1/foos/00000d/bars/000014/boots'
HTTP/1.1 200 OK
Status: 200
Access-Control-Allow-Origin: *
Access-Control-Allow-Methods: POST, GET, OPTIONS
Access-Control-Allow-Headers: DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,X-Auth-Token
Content-Length: 0
看起来不错,现在 GET:
curl -i -H'Accept: application/json' -H'X-Auth-Token: pAWp5hrCmXA83GgFzgHC' -XGET 'http://api.mydomain.net/v1/foos/00000d/bars/000014/boots'
HTTP/1.1 204 No Content
Status: 204
Cache-Control: no-cache
Content-Length: 0
Content-Type: text/plain
如果我请求包含至少一个对象的靴子集合,一切正常。我的服务器的 CORS 标头以 arr 响应,我认为完全没问题。那么为什么浏览器会报告跨源资源问题呢?
是因为text/plain
我的 204 响应的内容类型吗?