我是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。
你可以告诉我这里发生了什么吗? : - )谢谢!
答案 0 :(得分:1)
尝试在构造函数中向标题添加内容类型。
headers.append('Content-Type', 'application/json');