如何解决Angular http请求在“网络”选项卡上有两个调用可以吗
我一直在浏览器的“网络”选项卡上查看我的http请求,我发现每个呼叫都有两行。我不明白为什么会这样,如果还可以的话。
在后端,我可以看到其中一个调用为OPTIONS类型,另一个为GET类型。
呼叫GETUSUARIOX的功能
getUsuarios() {
const users$= this.http.get<HttpResponses>(this.apiUrl + 'getUsuariox').pipe(shareReplay());
users$.subscribe(res=>{
this.dataUsuarios = res;
this.dataUsuarios$.next(res.data);
})
return users$;
}
更新:
我刚刚意识到,使用OPTION方法进行的调用来自http拦截器,该拦截器将令牌添加到所有http请求中。运作正常吗?
解决方法
第一个请求是Pre-flight request。
从文档中
CORS预检请求是一种CORS请求,用于检查是否 了解CORS协议,并且服务器可以使用特定的 方法和标题。
这是一个OPTIONS请求,使用三个HTTP请求标头:
Access-Control-Request-Method
,Access-Control-Request-Headers
和Origin
标头。
不是Angular HTTP拦截器添加的不是。它由浏览器自动添加,以确保服务器遵守CORS并允许用户代理(浏览器)发出实际请求。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。