首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >AJAX POST请求在Safari 5中只工作一次

AJAX POST请求在Safari 5中只工作一次
EN

Stack Overflow用户
提问于 2011-09-30 16:15:13
回答 3查看 4.1K关注 0票数 2

我使用自己的自定义AJAX库(我对使用jQuery等不感兴趣),它在以下浏览器中运行得完美无缺:

  • Firefox 7
  • Chrome 14
  • IE8
  • IE8(兼容性模式)

在上述浏览器中使用我的自定义AJAX库,我可以按照任何顺序使用GET和/或POST方法发出任意数量的AJAX请求,并且它们都能完美地工作。由于为每个请求创建了一个新的AJAX对象(请参阅下面的代码),我甚至可以同时拥有多个AJAX请求进程。

但是,在Safari 5中,AJAX POST请求只有在绝对第一个执行AJAX请求时才会将POST数据传递给服务器。即使我连续两次执行完全相同的AJAX POST请求,POST数据也只在第一个请求期间传递给服务器。下面是我的自定义AJAX库中的JavaScript:

代码语言:javascript
运行
复制
if (!Array.indexOf)
{
    Array.prototype.indexOf = function(obj) { for (var i = 0; i < this.length; i++) { if (this[i] == obj) { return i; } } return -1; };
}

function ajaxObject()
{
    if (window.ActiveXObject)
    {
        var activexmodes = ["Msxml2.XMLHTTP", "Microsoft.XMLHTTP"];
        for (var i = 0; i < activexmodes.length; i++)
        {
            try
            {
                return new ActiveXObject(activexmodes[i]);
            }
            catch (e)
            {

            }
        }
    }
    else if (window.XMLHttpRequest)
    {
        return new XMLHttpRequest();
    }
    else
    {
        return false;
    }
}

function ajaxRequest(aURI, aContainerId, aPostData, aResponseType, aAvoidBrowserCache)
{
    // Initialize
    var xmlhttp = new ajaxObject();
    xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200)
        {
            if (aResponseType != "eval" && aResponseType != "EVAL")
            {
                // Show HTML for response
                document.getElementById(aContainerId).innerHTML = xmlhttp.responseText;
            }
            else
            {
                // Parse & execute JavaScript for response
                var responseText = xmlhttp.responseText;
                var startPos, endPos;
                for (var i = 0; i < responseText.length; i++)
                {
                    if (responseText.substring(i, i + 6) == "<eval>")
                    {
                        startPos = i + 6;
                        break;
                    }
                }
                for (var i = startPos; i < responseText.length; i++)
                {
                    if (responseText.substring(i, i + 7) == "</eval>")
                    {
                        endPos = i;
                        break;
                    }
                }
                textToEval = responseText.substring(startPos, endPos);
                eval(textToEval);
            }
        }
        else
        {
            try
            {
                if (xmlhttp.status != 0 && xmlhttp.status != 200)
                {
                    alert('Error ' + xmlhttp.status);
                }
            }
            catch (e)
            {
                // Handle IE8 debug "unknown error"
            }
        }
    }
    if (aAvoidBrowserCache != false)
    {
        // Combat browser caching:
        aURI = aURI + (aURI.indexOf("?") == -1 ? "?" : "&");
        theTime = new Date().getTime();
        aURI = aURI + theTime + "=" + theTime;
    }
    // Make request
    if (typeof aPostData == "undefined" || aPostData == null || aPostData == "")
    {
        // GET request
        xmlhttp.open("GET", aURI, true);
        xmlhttp.send();
    }
    else
    {
        // POST request
        var parameters = "";
        if (aPostData.constructor.toString().indexOf("Array") != -1)
        {
            // Use parameters passed as array
            for (var postCount = 0; postCount < aPostData.length; postCount++)
            {
                if (parameters != "")
                {
                    parameters = parameters + "&";
                }
                parameters = parameters + aPostData[postCount][0] + "=" + encodeURIComponent(aPostData[postCount][1]);
            }
        }
        else
        {
            // Use parameters passed as string
            parameters = aPostData;
        }
        xmlhttp.open("POST", aURI, true);
        xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
        xmlhttp.send(parameters);
    }
}

因此,例如,如果下面的AJAX POST请求是绝对的第一个AJAX请求(无论是GET还是POST ),它们中的任何一个都将传递POST数据;否则,将不会传递POST数据:

代码语言:javascript
运行
复制
ajaxRequest("test.aspx", "", [["name1","value1"],["name2","value2"]], "eval");

代码语言:javascript
运行
复制
ajaxRequest("test.aspx", "", "name1=value1&name2=value2", "eval");

我在整个AJAX库中都添加了调试语句,在每个POST请求之前,POST参数将按照预期在" parameters“变量中创建。我完全不知道为什么,只有在Safari 5(在提到的浏览器),我有这个问题。有什么想法吗?

提前感谢!杰西

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-04-26 06:55:12

调用失败的原因是在IIS下使用Windows身份验证时Safari中有错误。转到网站的身份验证设置。右键单击Windows身份验证,选择提供程序并删除协商,使NTLM正常工作。我还没测试过Kerberos。

此问题只出现在某些版本的safari中。

票数 7
EN

Stack Overflow用户

发布于 2011-11-21 10:25:53

从你提到的那条线过来可能是个骗局。我从来没有解决我们的问题,但你有没有尝试过一个简单的网页发布请求?就我们的问题而言,这是一个post问题,而不是AJAX问题,尽管如此,我们仍然感到困惑。

您在服务器上运行什么版本的IIS?

票数 0
EN

Stack Overflow用户

发布于 2012-01-27 15:07:06

我可以确认这个问题似乎与Safari和IIS之间的某种交互有关。幸运的是,我只在Windows上开发和测试这部分代码。我将它不变地移到LAMP (Linux/Apache)临时服务器(在转移到LAMP生产服务器之前),问题就消失了。我看到了Safari 5、IIS5.1&一个ActiveState Perl5.6CGI的问题。

在RHEL 5、Apache2.2和Perl 5.8下,它已经消失。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7613196

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档