我正尝试使用Angular 2的HTTP.get()方法从本地主机发出Google Maps API JavaScript请求。在我的请求中,我需要添加标题,但我试图执行此操作,但收到此错误通知:Angular 2:Google Maps API请求:不存在'Access-Control-Allow-Origin'标头
https://maps.googleapis.com/maps/api/place/textsearch/json?query=Santa+Cruz&key=MY_KEY。 对预检请求的响应未通过访问控制检查:否 请求的 资源上存在“访问控制 - 允许来源”标头。原因'http://localhost:51268'因此不允许 访问。
我想要做的就是输入一个城市名称并将响应返回给JSON对象。有人能解释我在这里做错了吗? Web检查上市
import {Injectable} from '@angular/core';
import {Http, Headers, RequestOptions} from '@angular/http';
import { Observable } from 'rxjs/Rx';
@Injectable()
export class SearchService {
dataHere: Object;
errorMessage: String;
constructor(private http: Http) { }
getPlaces(name: String): Observable<any> {
const url = "https://maps.googleapis.com/maps/api/place/textsearch/json?query=Santa+Cruz&key=MY_KEY";
let headers = new Headers({ 'Access-Control-Allow-Origin': '*','Content-Type': 'application/json' });
let options = new RequestOptions({ headers: headers });
return this.http.get(url, options)
.map(r => this.dataHere = r.json())
.catch((error:any) => Observable.throw(error.json().error));
}
private handleError(error: any): Promise<any> {
console.error('An error occurred', error); // for demo purposes only
return Promise.reject(error.message || error);
}
}
错误:
您可以下载[Chrome CORS扩展](https://chrome.google.com/webstore/detail/allow-control-allow-origi/nlfbmbojpeacfghkpbjhddihlkkiljbi?hl=en)并使用滑动条,可以打开/关闭'Access-Control-Allow-Origin'。你的方式:整个网络安全是关闭的。 – xmux