这是我使用的代码如下:
我使用的是IE9,无法在"网络"选项卡中看到正在发送的请求.我确实在JSP中设置了Access-Control标头:
<% response.setHeader("Access-Control-Allow-Origin", "*");%>
Run Code Online (Sandbox Code Playgroud)
从JSP获取AJAX HTML内容的代码:
if ($.browser.msie && window.XDomainRequest) {
var xdr = new window.XDomainRequest();
xdr.open("GET", "http://dev01.org:11110/crs/qw/qw.jsp?&_=" + Math.random());
xdr.contentType = "text/plain";
xdr.timeout = 5000;
xdr.onerror = function () {
console.log('we have an error!');
}
xdr.onprogress = function () {
console.log('this sucks!');
};
xdr.ontimeout = function () {
console.log('it timed out!');
};
xdr.onopen = function () {
console.log('we open the xdomainrequest');
};
xdr.onload = function() {
alert(xdr.responseText);
};
xdr.send(null);
} else { ...... }
Run Code Online (Sandbox Code Playgroud)
我得到一个访问被拒绝错误.任何帮助将非常感激!
请求必须针对与托管页面相同的方案
在您的示例中,您正在请求:
http://dev01 ...
Run Code Online (Sandbox Code Playgroud)
您应该通过 HTTP 协议执行此操作。
例如:如果您的网站,js脚本所在位置:http://dev.org
您可以这样做:
xhr = new XDomainRequest();
xhr.open("GET", "http://dev01.org?p=1");
Run Code Online (Sandbox Code Playgroud)
但这会引发“访问被拒绝”:
xhr = new XDomainRequest();
xhr.open("GET", "https://dev01.org?p=1");
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
3320 次 |
最近记录: |