当使用Angular/Ionic在浏览器上尝试访问不在同一域名下的API时,可能会遇到CORS策略问题。这是因为浏览器执行了预检请求,并检查响应中的Access-Control-Allow-Origin标头。如果响应未包含正确的标头,则浏览器将拒绝访问API。要解决这个问题,您可以在API端点上配置正确的CORS标头,或使用代理工具(例如ng2-proxy)。
以下是使用ng2-proxy来解决CORS问题的示例。首先安装ng2-proxy:
npm install ng2-proxy --save
然后在Angular应用程序中添加以下配置:
import {Component} from '@angular/core';
import {ProxyHttpService} from 'ng2-proxy';
import {Http, Headers} from '@angular/http';
@Component({
selector: 'app-root',
template: ``
})
export class AppComponent {
constructor(private http: Http, private proxyService: ProxyHttpService) {
}
getData() {
const headers: Headers = new Headers({'Content-Type': 'application/json'});
this.proxyService.request({
url: 'http://example.com/api/data',
method: 'get',
headers
}).subscribe(response => {
console.log(response.json());
});
}
}
此代码将在端口4200上启动Angular应用程序。运行示例后,单击“GetData”按钮,该按钮将代理请求发送到示例URL。代理处理预检请求,然后在响应中包含正确的Access-Control-Allow-Origin标头,使浏览器能够访问API。