Javascript 从HTTP到HTTPS的AJAX
在我的页面上,我有一个带有输入字段的表单。在提交此表单时,我使用JavaSript函数“test_kod(this)”验证输入值是否正确。但是在InternetExplorer版本中,您提出了一个跨源请求。由于它在非IE9的浏览器上工作,您可能已经设置了CORS来授予权限(尽管将HTTPS数据拉到HTTP页面上会使加密变得毫无价值) IE在IE 10之前不支持带有XMLHttpRequest的CORS。在此之前,您需要使用Javascript 从HTTP到HTTPS的AJAX,javascript,ajax,http,https,mootools,Javascript,Ajax,Http,Https,Mootools,在我的页面上,我有一个带有输入字段的表单。在提交此表单时,我使用JavaSript函数“test_kod(this)”验证输入值是否正确。但是在InternetExplorer版本中,您提出了一个跨源请求。由于它在非IE9的浏览器上工作,您可能已经设置了CORS来授予权限(尽管将HTTPS数据拉到HTTP页面上会使加密变得毫无价值) IE在IE 10之前不支持带有XMLHttpRequest的CORS。在此之前,您需要使用XDomainRequest。它的用途很简单 我会将HTML文档改为HTT
XDomainRequest
。它的用途很简单
我会将HTML文档改为HTTPS,因为这将同时解决跨源和安全问题。如果您使用mootools,为什么要重新实现
请求
?我也试过了。但是,当我尝试从HTTP访问HTTPSI时,也出现了同样的问题。我使用XDomainRequest添加了不同版本的脚本。但是HTTP和HTTPS请求之间仍然存在问题,我必须使用IE8来满足这个需求。我将XMLHttpRequest更改为XDomainRequest,访问被拒绝
仍被抛出。
function test_kod(field) {
var req = createXMLHTTPObject();
if (!req) {
return false;
};
try {
//in IE <= 9 in this place debuger always return error "access denied"
req.open("GET","https://dad-atlas.datasolutions.pl/karta.php?karta="+field.value,false);
}
catch(e){
return false;
}
req.setRequestHeader('User-Agent','XMLHTTP/1.0');
req.onreadystatechange = function () {
if (req.readyState != 4) return;
if (req.status != 200 && req.status != 304) {
return false;
}
if (req.responseText == "TAK") {
return true;
} else {
return false;
};
}
if (req.readyState == 4) return;
req.send();
}
var XMLHttpFactories = [
function () {return new XMLHttpRequest()},
function () {return new ActiveXObject("Msxml2.XMLHTTP")},
function () {return new ActiveXObject("Msxml3.XMLHTTP")},
function () {return new ActiveXObject("Microsoft.XMLHTTP")}
];
function createXMLHTTPObject() {
var xmlhttp = false;
for (var i=0;i<XMLHttpFactories.length;i++) {
try {
xmlhttp = XMLHttpFactories[i]();
}
catch (e) {
continue;
}
break;
}
return xmlhttp;
}
function test_kod(field) {
var xhr = createCORSRequest('GET', "https://dad-atlas.datasolutions.pl/karta.php?karta="+field.value);
//var xhr = createCORSRequest('GET', "http://facebook.com");
if (!xhr) {
alert('CORS not supported');
return false;
}
// Response handlers.
xhr.onload = function() {
var text = xhr.responseText;
var title = getTitle(text);
alert('Response from CORS request to ' + url + ': ' + title);
};
xhr.onerror = function() {
alert('Woops, there was an error making the request.');
};
xhr.send();
}
// Create the XHR object.
function createCORSRequest(method, url) {
var xhr = new XMLHttpRequest();
if ("withCredentials" in xhr) {
// XHR for Chrome/Firefox/Opera/Safari.
xhr.open(method, url, true);
alert("Firefox open");
} else if (typeof XDomainRequest != "undefined") {
// XDomainRequest for IE.
xhr = new XDomainRequest();
xhr.open(method, url);
alert("IE open");
} else {
alert('CORS not supported');
xhr = null;
}
return xhr;
}
// Helper method to parse the title tag from the response.
function getTitle(text) {
return text.match('<title>(.*)?</title>')[1];
}