【发布时间】:2016-04-12 12:34:36
【问题描述】:
我有两个应用,一个是 react 前端,第二个是 rails-api 应用。
我一直很高兴使用isomorphic-fetch,直到我需要将 PATCH 方法发送到服务器。
我得到:
Fetch API cannot load http://localhost:3000/api/v1/tasks. Method patch is not allowed by Access-Control-Allow-Methods in preflight response.
但是来自服务器的 OPTIONS 响应在 Access-Control-Allow-Methods 列表中包含一个 PATCH 方法:
这是获取的实现方式:
const API_URL = 'http://localhost:3000/'
const API_PATH = 'api/v1/'
fetch(API_URL + API_PATH + 'tasks', {
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
},
method: 'patch',
body: JSON.stringify( { task: task } )
})
POST、GET、DELETE 的设置几乎相同,并且工作正常。
知道这里发生了什么吗?
更新:
方法补丁区分大小写:
https://github.com/github/fetch/blob/master/fetch.js#L200
不确定这是故意还是错误。
更新 2
这是有意的,方法类型 PATCH 需要区分大小写。 将 fetch 方法的行更新为:
method: 'PATCH'
解决问题。
【问题讨论】:
-
看起来 isomorphic-fetch 中可能存在错误,因为如果我将方法名称更改为 POST,请求将起作用,但 post 不区分大小写,get delete....跨度>
-
附带说明,在对
OPTIONS请求的响应中允许的方法的标头是Allow:。您的回复使用了不同的标头 (Access-Control-Allow-Methods:)。 -
无论如何我认为您应该将其添加为答案,因为它是您问题的解决方案。
-
让我了解了调查结果——将“补丁”更改为“补丁”解决了这个问题。当您需要它们时,内置枚举在哪里? :) 感谢您发布更新。
-
与@JamesPerih 相同...用
'PATCH'替换'patch'解决了“问题”:/
标签: javascript php ruby-on-rails fetch-api