- 相關(guān)推薦
PHP處理Ajax請(qǐng)求與Ajax跨域問(wèn)題
這篇文章主要介紹了PHP處理Ajax請(qǐng)求與Ajax跨域問(wèn)題的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下,就跟隨百分網(wǎng)小編一起去了解下吧,想了解更多相關(guān)信息請(qǐng)持續(xù)關(guān)注我們應(yīng)屆畢業(yè)生考試網(wǎng)!
PHP判斷是否為Ajax請(qǐng)求
我們知道,在發(fā)送ajax請(qǐng)求的時(shí)候,可以通過(guò)XMLHttpRequest這個(gè)對(duì)象,創(chuàng)建自定義的header頭信息, 在jquery框架中,對(duì)于通過(guò)它的$.ajax, $.get, 或者$.post方法請(qǐng)求網(wǎng)頁(yè)內(nèi)容時(shí),它會(huì)向服務(wù)器傳遞一個(gè)HTTP_X_REQUESTED_WITH的參數(shù),php中就是在header一層判斷是否是ajax請(qǐng)求,對(duì)應(yīng)的根據(jù)$_SERVER['HTTP_X_REQUESTED_WITH']判斷。一般情況下$_SERVER['HTTP_X_REQUESTED_WITH']默認(rèn)是XMLHttpRequest,$_SERVER['HTTP_X_REQUESTED_WITH']也可以自定義創(chuàng)建的,使用XMLHttpRequest.setRequestHeader(name,value)。
示例:前端頁(yè)面發(fā)送普通的ajax請(qǐng)求給后端test.php。
?
1
2
3
4
5
6
7
$.ajax({
type: "GET",
url: 'test.php',
success: function(data) {
console.log(data);
}
});
服務(wù)端test.php可以判斷該請(qǐng)求是不是Ajax異步請(qǐng)求,然后根據(jù)業(yè)務(wù)需求做出響應(yīng)的回應(yīng)。
以下是服務(wù)端test.php的簡(jiǎn)單驗(yàn)證是否為ajax請(qǐng)求的代碼:
?
1
2
3
4
5
6
7
8
function isAjax() {
return @$_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest' ? true : false;
}
if (isAjax()) {
echo 'Ajax Request Success.';
} else {
echo 'No.';
}
Ajax發(fā)起JSONP跨域請(qǐng)求
我們通過(guò)jQuery的JSONP方式可以實(shí)現(xiàn)跨域ajax請(qǐng)求,服務(wù)端php也需要做出相應(yīng)的處理,也就是說(shuō)php這邊必須和前端頁(yè)面按照一定的格式請(qǐng)求和返回?cái)?shù)據(jù)。
示例:前端頁(yè)面發(fā)起JSONP請(qǐng)求:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
$.ajax({
type: "get",
data: "random="+Math.random(),
url: "http://demo.jb51.net/phpajax/jsonp.php",
dataType: "jsonp",
jsonp: "callback",
success: function(data) {
console.log(data);
},
error: function() {
console.log('Request Error.');
}
});
我們會(huì)發(fā)現(xiàn),ajax請(qǐng)求參數(shù)中有 dataType: "jsonp" 和 jsonp: "callback" ,這個(gè)就表明了我要請(qǐng)求的是jsonp,并且會(huì)有回調(diào)callback返回。當(dāng)然,我們也可以自定義回調(diào)函數(shù),如 jsonpCallback:"success_jsonpCallback"
還可以簡(jiǎn)單的寫(xiě)成:
?
1
2
3
4
5
jQuery.getJSON('http://demo.jb51.net/phpajax/jsonp.php?callback=?",{
random: Math.random()
}, function(data){
console.log(data);
});
php后端服務(wù)代碼可以這樣寫(xiě)(注意輸出返回的格式):
?
1
2
3
4
5
$data = array(
'rand' => $_GET['random'],
'msg' => 'Success'
);
echo $_GET['callback'].'('.json_encode($data).')';
Ajax跨域請(qǐng)求:CORS
CORS,又稱跨域資源共享,英文全稱Cross-Origin Resource Sharing。假設(shè)我們想使用Ajax從a.com的頁(yè)面上向b.com的頁(yè)面上要點(diǎn)數(shù)據(jù),通常情況由于同源策略,這種請(qǐng)求是不允許的,瀏覽器也會(huì)返回“源不匹配”的錯(cuò)誤,所以就有了“跨域”這個(gè)說(shuō)法。但是我們也有解決辦法,我們可以再b.com的頁(yè)面header信息中增加一行代碼:
?
1
header("Access-Control-Allow-Origin: *");
當(dāng)我們?cè)O(shè)置的header為以上信息時(shí),任意一個(gè)請(qǐng)求過(guò)來(lái)之后服務(wù)端我們都可以進(jìn)行處理和響應(yīng),那么在調(diào)試工具中可以看到其頭信息設(shè)置,其中見(jiàn)紅框中有一項(xiàng)信息是“*Access-Control-Allow-Origin:* ”,表示我們已經(jīng)啟用CORS,如果要限制只允許某個(gè)域名的請(qǐng)求,可以這樣:
?
1
header("Access-Control-Allow-Origin: http://www.jb51.net");
示例:通過(guò)CORS跨域請(qǐng)求數(shù)據(jù)
?
1
2
3
4
5
6
7
8
9
10
11
12
13
$.ajax({
type: "get",
data: "random="+Math.random(),
url: "http://demo.jb51.net/phpajax/ajax.php",
dataType: "json",
success: function(data) {
console.log(data);
$("#result_3").html(data.msg+':'+data.rand);
},
error: function() {
$("#result_3").html('Request Error.');
}
});
我們?cè)诹硪粋(gè)網(wǎng)站域名下的ajax.php加上這樣的代碼:
?
1
2
3
4
5
6
header("Access-Control-Allow-Origin: http://www.jb51.net");
$data = array(
'rand' => $_GET['random'],
'msg' => 'Success'
);
echo json_encode($data);
這就實(shí)現(xiàn)了從www.jb51.net頁(yè)面發(fā)起跨域異步請(qǐng)求到域名路徑demo.jb51.net/phpajax/ajax.php,并得到響應(yīng)。
以上所述是小編給大家介紹的PHP處理Ajax請(qǐng)求與Ajax跨域,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
【PHP處理Ajax請(qǐng)求與Ajax跨域問(wèn)題】相關(guān)文章:
基于PHP+Ajax實(shí)現(xiàn)表單驗(yàn)證的詳解03-03
PHP怎么處理密碼08-28
PHP如何使用curl發(fā)送GET和POST請(qǐng)求03-24
PHP如何用curl發(fā)送GET和POST請(qǐng)求03-02
PHP處理密碼的幾種方式實(shí)例03-29
php常用的url處理函數(shù)集03-20
PHP中使用cURL實(shí)現(xiàn)Get和Post請(qǐng)求的方法12-03
完美解決PHP中文亂碼問(wèn)題12-06
php字符串截取問(wèn)題11-17