我必须使用带有跨域 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) . ')';
}
?>
谢谢你的帮助!