【发布时间】:2016-10-14 21:55:48
【问题描述】:
我发出一个 POST 请求,但该请求一直处于等待状态,直到最终失败。我已经监视了 nginx 日志和节点服务器日志,并且请求甚至没有注册。这适用于我测试过的其他任何人,除了另一位同事。如果我使用边缘浏览器或其他计算机,它可以正常工作。
我试图向其他(自定义)服务器发出 POST 请求,它也挂在那里的选项上。我也用 jQuery 发出了 POST 请求,但同样失败了。
值得注意的是,我正在使用 withCredentials 标志。
标题:
Provisional headers are shown
Access-Control-Request-Headers:content-type
Access-Control-Request-Method:GET
Origin:http://localhost:8080
Referer:http://localhost:8080/<path>
User-Agent:Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.84 Safari/537.36
请求:
public login(user) {
const endpoint = `http://<url>`;
let headers = new Headers();
headers.append('Content-type', 'application/json');
return this.http
.post(endpoint, JSON.stringify(user), {
headers: headers,
});
}
我在我的组件中订阅了调用:
this._accountService.login(this.user)
.subscribe(res => {
console.log("logged in!");
if (res.json().status === "success") {
window.location.href = `/home/${this.org}/${this.product}`;
}
else {
// What other options are there?
console.log("Do something else maybe?");
}
},
err => {
this.invalidLogin = true;
console.log("Ye shall not pass!");
});
成功用户的标题
Accept:*/*
Accept-Encoding:gzip, deflate, sdch
Accept-Language:en-US,en;q=0.8
Access-Control-Request-Headers:content-type
Access-Control-Request-Method:POST
Connection:keep-alive
Host:<url>
Origin:<url>
Referer:<url>
User-Agent:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.33 Safari/537.36
来自 chrome://net-internals/#events
t=61869793 [st= 0] +REQUEST_ALIVE [dt=60162]
--> has_upload = false
--> is_pending = true
--> load_flags = 34624 (DO_NOT_SAVE_COOKIES | DO_NOT_SEND_AUTH_DATA | DO_NOT_SEND_COOKIES | MAYBE_USER_GESTURE | VERIFY_EV_CERT)
--> load_state = 14 (WAITING_FOR_RESPONSE)
--> method = "OPTIONS"
--> net_error = -1 (ERR_IO_PENDING)
--> status = "IO_PENDING"
--> url = "<url>"
t=61929955 [st=60162] -HTTP_STREAM_PARSER_READ_HEADERS
--> net_error = -324 (ERR_EMPTY_RESPONSE)
t=61929955 [st=60162] -HTTP_TRANSACTION_READ_HEADERS
--> net_error = -324 (ERR_EMPTY_RESPONSE)
t=61929955 [st=60162] -URL_REQUEST_START_JOB
--> net_error = -324 (ERR_EMPTY_RESPONSE)
t=61929955 [st=60162] URL_REQUEST_DELEGATE [dt=0]
t=61929955 [st=60162] -REQUEST_ALIVE
--> net_error = -324 (ERR_EMPTY_RESPONSE)
我真的猜测这与我的浏览器中缓存的某些内容有关,但我真的找不到什么。我已经清除了所有 cookie 和任何可以存储的东西。我还能在哪里检查以清除东西?这显然是我的计算机/浏览器(以及另一个不幸的人)本地的东西。
【问题讨论】:
-
这与 Angular 无关。您正在访问的服务器需要支持 CORS 请求。
OPTIONS是浏览器自动发出的预检请求。如果它没有返回预期的Access-Control-Allow-...标头,它甚至不会尝试发送实际请求。 -
@GünterZöchbauer 我启用了 CORS。该请求适用于其他计算机和浏览器。
-
您需要发布服务器接收到的标头以及它响应 OPTIONS 请求的标头,以便任何人都能够提供帮助。从计算机发出的请求中查看发送的标头会很有帮助,这些请求也适用于比较。
-
@GünterZöchbauer 好电话,我已相应更新。
标签: javascript xmlhttprequest cors