Angular2 Firebase:预检的响应具有无效的HTTP状态代码405

时间:2017-11-18 15:03:33

标签: angular firebase angular2-services

我是Angular2的新手。在尝试从Firebase API获取值时,我遇到错误:

OPTIONS https://udemy-ng-http.firebaseio.com/data 405 (Method Not Allowed)

Failed to load https://udemy-ng-http.firebaseio.com/data: Response for preflight has 

invalid HTTP status code 405

但我可以将数据发布到Firebase API端点。

我也尝试过在这个社区提供的其他解决方案,但它没有帮助。以下是我的代码。

代码:

 getServer(){
    let headers = new Headers();
    headers.append('Access-Control-Allow-Headers', 'Content-Type');
    headers.append('Access-Control-Allow-Origin', '*');
    headers.append('Content-Type', 'application/json') ;
    headers.append('charset','UTF-8');
    headers.append('Accept','application/json');
    let options = new RequestOptions({ headers: headers });

    return this.http.get('https://udemy-ng-http.firebaseio.com/data',options)
        .map(
            (response: Response) => {
                const data = response.json();
                for (const server of data) {
                  server.name = 'FETCHED_' + server.name;
                }
                return data;
            }
        )
        .catch(
            (error: Response) => {
              return Observable.throw('Something went wrong');
            }
        );
}

2 个答案:

答案 0 :(得分:2)

您需要将.json添加到您的端点。尝试点击https://udemy-ng-http.firebaseio.com/data.json。它给出了404.你可以尝试点击你创建的那个。请看看我创建的插件。

https://plnkr.co/edit/ZTZ9QXsDWRlvboPh2OEu?p=preview

let _url = 'https://irelief-3ff8d.firebaseio.com/bookings.json';
    //https://udemy-ng-http.firebaseio.com/data
     this.http.get(_url, { headers: headers }).subscribe((response)=>{
      alert('response >> '+JSON.stringify(response));
      this.responseData = response;
    },err => alert('status : '+err.status)));

您需要使用自己的应用替换网址。希望这可以帮助。

P.S。我在这个例子中使用角度版本4.4.6。

答案 1 :(得分:2)

尝试删除.//*[contains(@class, 'NAME_')]

Firebase小组提供了两个sample functions来演示CORS的使用:

第二个示例使用与您当前使用的不同的cors方式。

另外,请考虑像这样导入,如示例所示:

headers.append('Access-Control-Allow-Origin', '*');