在angular2上出现404错误.get

时间:2016-12-18 17:31:53

标签: angular

我是angular2的新手,我试图基于angular2 quickstart项目开发自己的应用程序。

所以问题是:当我尝试使用真正的API来获取数据时,我总是出现404错误(无论API网址是什么)。

这是我的服务代码:

import { Injectable }    from '@angular/core';
import { Headers, Http, Response } from '@angular/http';

import { League } from './league';
import { Observable }     from 'rxjs/Observable';

@Injectable()
export class LeagueService {

 private headers = new Headers({'X-Mashape-Key': 'MY_API_KEY'});
 private leaguesUrl = 'https://sportsop-soccer-sports-open-data-v1.p.mashape.com/v1/leagues';

 constructor(private http: Http) {}

 getLeagues(): Observable<League[]> {
    return this.http.get(this.leaguesUrl,{headers: this.headers})
                .map(this.extractData)
                .catch(this.handleError);
 }

 private extractData(res: Response) {
    let body = res.json();
    return body.data || { };
 }

  private handleError (error: Response | any) {
    // In a real world app, we might use a remote logging infrastructure
    let errMsg: string;
    if (error instanceof Response) {
      const body = error.json() || '';
      const err = body.error || JSON.stringify(body);
      errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
    } else {
      errMsg = error.message ? error.message : error.toString();
    }
    console.error(errMsg);
    return Observable.throw(errMsg);
  }
}

handleError方法向我发送了回复:“未找到未找到的集合'联盟'”。我已经尝试过承诺和可观察的。

我知道这个API可用且不会发回404。

你可以告诉我这里发生了什么吗? : - )

谢谢!

1 个答案:

答案 0 :(得分:1)

尝试在构造函数中向标题添加内容类型。

headers.append('Content-Type', 'application/json');