Angular2 OPTIONS方法发送时要求http.GET

前端之家收集整理的这篇文章主要介绍了Angular2 OPTIONS方法发送时要求http.GET前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > Why am I getting an OPTIONS request instead of a GET request?6
我试图添加 basic authentification到我的angular2应用程序.
public login() {
    // Set basic auth headers
    this.defaultHeaders.set('Authorization','Basic ' + btoa(this.username + ':' + this.password));

    console.log('username',this.username)
    console.log('password',this.password)
    console.log(this.defaultHeaders)

    // rest is copy paste from monbanquetapiservice
    const path = this.basePath + '/api/v1/development/order';        

    let req = this.http.get(path,{ headers: this.defaultHeaders });
    req.subscribe(
        _ => { },err => this.onError(err)
    );
}

我期望看到的是一个GET请求与我授权代理人.

但是我看到的是第一个这个标题的选项:

OPTIONS /api/v1/development/order HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Access-Control-Request-Method: GET
Origin: http://localhost:3000
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_3) AppleWebKit/537.36 (KHTML,like Gecko) Chrome/49.0.2623.110 Safari/537.36
Access-Control-Request-Headers: authorization,content-type
Accept: */*
Referer: http://localhost:3000/
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-GB,en-US;q=0.8,en;q=0.6,fr;q=0.4

由于我的服务器不允许在这个URL上的OPTIONS,我收到一个错误.

我知道像PUT或POST这样的一些方法首先发送一个OPTIONS方法来预先请求请求,但是GET不会.

为什么angular2的http首先发送选项?

谢谢.

这是CORS工作的方式(使用跨域请求时).使用CORS,远程Web应用程序(这里是域mydomain.org)选择是否可以通过一组特定头文件来提供请求.

CORS规范区分了两个不同的用例:

>简单请求如果我们使用HTTP GET,HEAD和POST方法,则适用此用例.在POST方法的情况下,仅支持具有以下值的内容类型:text / plain,application / x-www-form-urlencoded和multipart / form-data.
>预检索请求当“简单请求”用例不适用时,将使用第一个请求(使用HTTP OPTIONS方法)来检查在跨域请求的上下文中可以执行的操作.

它不是Angular2发送OPTIONS请求,而是浏览器本身.这与Angular并不相关.

有关详细信息,请参阅本文:

> http://restlet.com/blog/2015/12/15/understanding-and-using-cors/

猜你在找的Angularjs相关文章