【发布时间】:2016-08-06 11:54:41
【问题描述】:
您如何 return 来自 CORS 请求的响应代码?我可以从 onload 事件中获取它,但我似乎无法将其取出并创建一个 return 以便我可以捕获它以进行值检查。
这是我基于http://www.html5rocks.com/en/tutorials/cors/的代码:
createCORSRequest: function(method, url) {
var xhr = new XMLHttpRequest();
if ("withCredentials" in xhr) {
// Check if the XMLHttpRequest object has a "withCredentials" property.
// "withCredentials" only exists on XMLHTTPRequest2 objects.
xhr.open(method, url, true);
} else if (typeof XDomainRequest != "undefined") {
// Otherwise, check if XDomainRequest.
// XDomainRequest only exists in IE, and is IE's way of making CORS requests.
xhr = new XDomainRequest();
xhr.open(method, url);
} else {
// Otherwise, CORS is not supported by the browser.
xhr = null;
}
return xhr;
},
makeCorsRequest: function() {
// All HTML5 Rocks properties support CORS.
var me = this;
var url = 'http://google.com';
var sCode = '';
var xhr = me.createCORSRequest('GET', url);
console.log('xhr', xhr);
if (!xhr) {
alert('CORS not supported');
return;
}
// Response handlers.
xhr.onload = function() {
var text = xhr.responseText;
var sCode = xhr.status;
// var title = getTitle(text);
// alert('Response from CORS request to ' + url + ': ' + xhr.status);
};
xhr.onreadystatechange = function() {
console.log(this.status);
sCode = this.status;
}
xhr.onerror = function() {
alert('Woops, there was an error making the request.');
};
xhr.send();
return sCode; // this returns an empty string or the initial value set to it and not from `onload` event
}
【问题讨论】:
-
看起来您在返回响应之前返回了“状态”。您可能需要考虑到
onerror、onload等事件将被异步触发,只有这样您才能使用status代码。回调或承诺可能会有所帮助。 -
你能分享一下你是如何打电话给
makeCorsRequest的吗? -
嗨@AnkitMishra。我正在使用 AngularJS,所以我从我的工厂调用它:
statusCode = $payments.makeCorsRequest(); -
@AnkitMishra:不确定如何用 Angular 编写。我假设它是以我为 $http 编写成功/错误回调的方式实现的?
标签: javascript angularjs cors