我开发了一个PhoneGap 应用程序,现在它正在转变为一个移动网站。除了一个小故障外,一切都很顺利。我通过 POST 请求使用某个第三方 API,它在应用程序中运行良好,但在移动网站版本中失败。
仔细一看,AngularJS(我猜实际上是浏览器)似乎首先发送了一个 OPTIONS 请求。我今天学到了很多关于 CORS 的知识,但我似乎无法弄清楚如何完全禁用它。我无权访问该 API(因此无法在该端进行更改),但他们已将我正在处理的域添加到他们的 Access-Control-Allow-Origin 标头中。
这是我正在谈论的代码:
var request = {
language: 'fr',
barcodes: [
{
barcode: 'somebarcode',
description: 'Description goes here'
}
]
};
}
var config = {
headers: {
'Cache-Control': 'no-cache',
'Content-Type': 'application/json'
}
};
$http.post('http://somedomain.be/trackinginfo', request, config).success(function(data, status) {
callback(undefined, data);
}).error(function(data, status) {
var err = new Error('Error message');
err.status = status;
callback(err);
});
如何防止浏览器(或 AngularJS)发送该 OPTIONS 请求而直接跳到实际的 POST 请求?我正在使用 AngularJS 1.2.0。
提前致谢。