1

我必须使用带有跨域 AJAX 请求的 JQuery 和 PHP 创建一个 Web 应用程序。所以,我使用 JSONP 来完成我的请求。它在 Firefox 上运行良好,但不适用于 Chrome 和 Opera。

我有一个执行请求的功能:

function update()
{
    $.ajax({
        url : url,
        type : "GET",
        dataType: "jsonp",
        crossDomain : true,
        jsonpCallback : "updateCallback",
        async : false, 
        data : {'session_id' : sessionID,'user' : userName },
        error : function (xhr, status, error) {
            alert("Erreur de chargement du fichier '"+url+"' : "+xhr.responseText+" ("+status+" - "+error+")");
        },
        success: function(){
            alert("Success !");
        }
    });
}

这是回调函数:

function updateCallback(data)
{     
    var i = 0;
    var messages = data.messages;

    while(i < data.messages.length){  
       appendMessage(data.messages[i]);
       i++;
    }

    saveLastMsgID = lastMsgID;
    doUpdate = updateInProgress = false;
}

AJAX 请求调用的 PHP 脚本:

<?php

/* ... */ 

function sendResponse($messages,$date)
{
    header('content-type: application/json; charset=utf-8'); 
    header("Access-control-allow-origin: *");
    header ("Access-Control-Allow-Headers: x-requested-with", true);
    header('Access-Control-Allow-Methods: GET,OPTIONS');

    $datas = array();

    for($i = 0 ; $i < count($messages) ; $i++){
        $msg = $messages[$i];
        $message = null;
        $message->sender = $msg->getSender();
        $message->date = $date;
        $message->msg = stripslashes($msg->getContent());
        $message->carrier = $carrier;
        $datas[] = $message;
    }
    $data->messages = $datas;
    echo $_GET['callback']. '('. json_encode($data) . ')'; 
}
?>

谢谢你的帮助!

4

3 回答 3

3

伙计,你那里有很多东西。这不是真的必要。尝试这个。它让 jQuery 处理您的回调,以便成功函数传递响应中嵌入的 JSON 表示的对象:

function update()
{
    $.ajax({
        url : url,
        dataType: "jsonp",
        // async : false, <-------- THIS IS IGNORED BY JQUERY DUE TO JSONP DATATYPE
        data : {'session_id' : sessionID,'user' : userName },
        success: function(data){
            // alert("Success !");
            var i = 0;
            var messages = data.messages;

            while(i < data.messages.length){  
               appendMessage(data.messages[i]);
               i++;
            }

            saveLastMsgID = lastMsgID;
            doUpdate = updateInProgress = false;
        }
    });
}
于 2012-05-08T14:47:59.800 回答
2

我想知道您是否在浏览器中安装了任何 adblock 插件,并且您的请求 url 包含一些关键字,例如“ad”。

我有类似的问题,最后发现是adblock导致了问题。

于 2013-03-12T14:55:15.400 回答
2

JSON-P 不是 JSON。它是嵌入在 JavaScript 程序中的 JSON。MIME 类型应该是application/javascript.

Chrome 和 Opera 可能正在对似乎试图将函数调用注入 JSON 字符串的行为做出反应。

于 2012-05-08T14:37:37.823 回答