调整ajax for crossdomain

时间:2011-07-10 10:48:41

标签: ajax cross-domain

是否可以针对跨域调整此代码以及如何

function makeRequest(url) {

    var http_request = false;

    if (window.XMLHttpRequest) { // Mozilla, Safari,...
        http_request = new XMLHttpRequest();
        if (http_request.overrideMimeType) {
                http_request.overrideMimeType('text/xml');
        }
    } else if (window.ActiveXObject) { // IE
        try {
            http_request = new ActiveXObject("Msxml2.XMLHTTP");
        } catch (e) {
            try {
            http_request = new ActiveXObject("Microsoft.XMLHTTP");
            } catch (e) {}
        }
    }

    if (!http_request) {
        alert('Cannot create an XMLHTTP instance');
        return false;
    }

    http_request.onreadystatechange = function() { alertContents(http_request); };
    http_request.open('GET', url, true);
    http_request.send(null);
}

function alertContents(http_request) {
    if (http_request.readyState == 4) {
        if (http_request.status == 200) {
            receiveData(http_request.responseText);
        } else {
            alert("Îòâåò ñåðâåðà ïîëó÷åí, íî åñòü îøèáêà");
        }         
    } 
}

1 个答案:

答案 0 :(得分:2)

same origin policy可以防止JavaScript在正常情况下从不同的来源读取数据。

你可以解决:

  1. 页面原点数据的代理
  2. JSONP
  3. CORSlimited browser support,但现在可能已经足够黄金时段了)