【问题标题】:How can I configure a proxy with my http request?如何使用我的 http 请求配置代理?
【发布时间】: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


【解决方案1】:

感谢您对“Cors 代理”的评论。

我找到了服务:http://cors-proxy.htmldriven.com,并且能够通过使用他们的 url 从 darksky 获取数据。

private weatherUrl = 'http://cors-proxy.htmldriven.com/?url=https://api.darksky.net/forecast/[key]/[latitude],[longitude]'

【讨论】: