【发布时间】:2018-01-06 14:56:54
【问题描述】:
我对 http 请求非常陌生,正在尝试使用 https://darksky.net/dev/docs/faq 获取数据。他们不支持 CORS,并建议我必须使用代理服务器来获取他们的数据。
我正在使用 Angular 并且正在为 http 请求使用服务:
import { Injectable } from '@angular/core';
import { Headers, Http } from '@angular/http';
import 'rxjs/add/operator/toPromise';
@Injectable()
export class ServiceWeather { // Unconventional but I see all my services when typing service
constructor(private http: Http) { }
private weatherUrl = 'https://api.darksky.net/forecast/[key]/[latitude],[longitude]'
public getWeather(): Promise<any> {
return this.http.get(this.weatherUrl)
.toPromise()
.then(response => response.json().data)
.catch(this.handleError);
}
private handleError(error: any): Promise<any> {
console.error('An error occurred', error);
return Promise.reject(error.message || error);
}
}
如何使用代理服务器进行配置?
需要有用的额外信息:我应该使用哪些代理服务器服务进行开发?
【问题讨论】:
-
如前所述,您需要一个代理服务器。你不能在客户端这样做。
-
只是说明我有多少不明白。我怎样才能做到这一点来实现我的目标?你能指出一些我应该阅读的教程或资源吗?
-
所以这个问题与 Angular 完全无关。谷歌搜索“cors 代理”并选择一个适合您的服务器设置。
-
谷歌它。如果还是想不通。然后就是您发布问题以及尝试的解决方案的时候了。
标签: angular http proxy same-origin-policy