对XMLHTTPRequest的后备支持

时间:2015-09-22 17:18:52

标签: javascript ajax xmlhttprequest msxml

我们有一个Web应用程序,它使用本机XMLHttpRequest()将数据发送回我们的服务器。我们的一个较大客户端的用户似乎在Win7(64位)中运行IE8,并且在其浏览器中禁用了“启用本机XMLHTTP支持”。

我们已经实现了实例化ActiveXObject代替XMLHttpRequest的典型场景,以便尝试支持IE6(不支持原生XMLHTTP;是的,我们仍然有客户端在瘦客户端上运行它!我希望IE8可以用作后备,如果这个复选框选项已被关闭。但是,一旦创建了一个对象,在调用open()方法时会出现类型错误。

这是我的代码:

// Posts back an xml file synchronously and checks for parse error.
// Returns xml object or null.  Used in RSUserData.
XML.PostXmlFile = function(sURL, doc)
{
    try
    {
        // Validate Input
        if ((typeof (sURL) != "string") || (sURL == ""))
            return null;

        if (window.XMLHttpRequest)  // IE7+, FF and Chrome
        {
            // Mozilla, create a new DOMParser and parse from string
            // Although IE9 and IE10 can successfully load XML using this block, it can't use document.evaluate nor selectNodes/selectSingleNode to navigate it
            // Ref: http://msdn.microsoft.com/en-us/library/ie/ms535874(v=vs.85).aspx
            // Ref: http://msdn.microsoft.com/en-us/library/ie/ms534370(v=vs.85).aspx
            // Ref: http://blogs.msdn.com/b/ie/archive/2012/07/19/xmlhttprequest-responsexml-in-ie10-release-preview.aspx
            var req = new XMLHttpRequest();
            req.open("post", sURL, false);
            req.send(doc);
            if (req.status != 200)
                throw { message: 'HTTP Post returned status ' + req.status + ' (' + req.statusText + ') when sending to ' + sURL };

            // IE11+:   req.responseXML returns a native XML Document
            // IE9/10:  req.responseXML returns an IXMLDOMDocument2 object but we can convert req.responseText to native XML using DOMParser
            // IE6/7/8: req.responseXML returns an IXMLDOMDocument2 object but DOMParser is not available

            if (window.DOMParser)
            {
                var parser = new DOMParser();
                return parser.parseFromString(req.responseText, 'application/xml');
            }
            else
                return req.responseXML;     // NATIVE
        }
        else
        {
            // up to IE6:
            // Ref: http://blogs.msdn.com/b/xmlteam/archive/2006/10/23/using-the-right-version-of-msxml-in-internet-explorer.aspx
            var oXML = XML.GetActiveX_XML();
            if (!oXML)
                throw { message: "Could not instantiate an Msxml2 ActiveXObject", innerException: e };

            oXML.open('POST', sURL, true);
            oXML.send(sFile);
            if (oXML.parseError.errorCode == 0)
            {
                xmlDoc = oXML;
                return xmlDoc;
            }
            return null;
        }

    }
    catch (e)
    {
        var s = "Exception in XML.PostXmlFile(). " + (e.message ? e.message : "");
        throw { message: s, innerException: e };
    }
}


XML.GetActiveX_XML = function()
{
    var progIDs = ['Msxml2.DOMDocument.6.0', 'Msxml2.DOMDocument.3.0'];
    for (var i = 0; i < progIDs.length; i++)
    {
        try
        {
            var oXML = new ActiveXObject(progIDs[i]);
            var sl = oXML.getProperty("SelectionLanguage");
            if (sl !== "XPath")
                oXML.setProperty("SelectionLanguage", "XPath"); // Changes v3.0 from XSLPattern to XPath

            var ns = "xmlns:rs='" + XML._nsResolver('rs') + "' xmlns:xsi='" + XML._nsResolver('xsi') + "'";
            //          ns = "xmlns:na='http://myserver.com' xmlns:nb='http://yourserver.com'";
            oXML.setProperty("SelectionNamespaces", ns);
            return oXML;
        }
        catch (ex) { }
    }
    return null;
}

注意:

  • 目的是使用网址和有效负载呼叫XML.PostXmlFile()
  • 现代浏览器按预期使用new XMLHttpRequest()
  • IE6预计会在XML.GetActiveX_XML()返回window.XMLHttpRequest
  • 的帐户中使用falsey
  • 禁用了“启用本机XMLHTTP支持”的IE8到IE6代码(因为window.XMLHttpRequest返回falsey)但实例化对象失败,因为它不支持open()方法( oXML.open('POST', sURL, true);

当禁用“启用本机XMLHTTP支持”时,有没有办法可以使用IE8发回我的有效负载?

1 个答案:

答案 0 :(得分:2)

在检查是否有Microsoft.XMLHTTP之前,您应该看XMLHttpRequest是否可用:

var bActiveX;

try {
  new ActiveXObject('Microsoft.XMLHTTP');
  bActiveX = true;
}
catch(e) {
  bActiveX = false;
}

然后,检查if条件:

if (window.XMLHttpRequest || bActiveX) { // IE7+, FF and Chrome
  var req = XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject('Microsoft.XMLHTTP');

  /* the rest of your code */
}