【发布时间】:2019-02-03 22:06:53
【问题描述】:
我有一个非常简单的 HTTP 调用:
fetch('http://127.0.0.1:5500/v1/homes/', {
method: "GET",
mode: "cors",
credentials: "same-origin",
headers: {
Authorization: "TEST"
}})
.then(function(response) {
console.log(response);
});
但是,当我查看 Google Chrome DevTools 的“网络”选项卡时,OPTIONS 请求中没有“授权”标头。这会导致服务器回复 401 Unauthorized。
浏览器的 curl 等效请求:
curl 'http://127.0.0.1:5500/v1/homes/' \
-X OPTIONS -H 'Access-Control-Request-Method: GET' \
-H 'Origin: http://localhost:8100'
-H 'Referer: http://localhost:8100/'
-H 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36'
-H 'Access-Control-Request-Headers: authorization'
--compressed
我是在客户端做错了什么,还是浏览器不发送 OPTIONS 请求中的 Authorization 标头很常见,因此,我需要更改服务器以响应 OPTIONS 调用而不需要 Authorization 标头?
【问题讨论】:
标签: javascript cors