PHP處理Ajax請求與Ajax跨域問題
PHP判斷是否為Ajax請求
我們知道,在發(fā)送ajax請求的時候,可以通過XMLHttpRequest這個對象,創(chuàng)建自定義的header頭信息, 在jquery框架中,對于通過它的$.ajax, $.get, 或者$.post方法請求網(wǎng)頁內(nèi)容時,它會向服務(wù)器傳遞一個HTTP_X_REQUESTED_WITH的參數(shù),php中就是在header一層判斷是否是ajax請求,對應(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)
。
示例:前端頁面發(fā)送普通的ajax請求給后端test.php。
$.ajax({ type: "GET", url: 'test.php', success: function(data) { console.log(data); } });
服務(wù)端test.php可以判斷該請求是不是Ajax異步請求,然后根據(jù)業(yè)務(wù)需求做出響應(yīng)的回應(yīng)。
以下是服務(wù)端test.php的簡單驗(yàn)證是否為ajax請求的代碼:
function isAjax() { return @$_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest' ? true : false; } if (isAjax()) { echo 'Ajax Request Success.'; } else { echo 'No.'; }
Ajax發(fā)起JSONP跨域請求
我們通過jQuery的JSONP方式可以實(shí)現(xiàn)跨域ajax請求,服務(wù)端php也需要做出相應(yīng)的處理,也就是說php這邊必須和前端頁面按照一定的格式請求和返回?cái)?shù)據(jù)。
示例:前端頁面發(fā)起JSONP請求:
$.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.'); } });
我們會發(fā)現(xiàn),ajax請求參數(shù)中有 dataType: "jsonp" 和 jsonp: "callback" ,這個就表明了我要請求的是jsonp,并且會有回調(diào)callback返回。當(dāng)然,我們也可以自定義回調(diào)函數(shù),如 jsonpCallback:"success_jsonpCallback"
還可以簡單的寫成:
jQuery.getJSON('http://demo.jb51.net/phpajax/jsonp.php?callback=?",{ random: Math.random() }, function(data){ console.log(data); });
php后端服務(wù)代碼可以這樣寫(注意輸出返回的格式):
$data = array( 'rand' => $_GET['random'], 'msg' => 'Success' ); echo $_GET['callback'].'('.json_encode($data).')';
Ajax跨域請求:CORS
CORS,又稱跨域資源共享,英文全稱Cross-Origin Resource Sharing。假設(shè)我們想使用Ajax從a.com的頁面上向b.com的頁面上要點(diǎn)數(shù)據(jù),通常情況由于同源策略,這種請求是不允許的,瀏覽器也會返回“源不匹配”的錯誤,所以就有了“跨域”這個說法。但是我們也有解決辦法,我們可以再b.com的頁面header信息中增加一行代碼:
header("Access-Control-Allow-Origin: *");
當(dāng)我們設(shè)置的header為以上信息時,任意一個請求過來之后服務(wù)端我們都可以進(jìn)行處理和響應(yīng),那么在調(diào)試工具中可以看到其頭信息設(shè)置,其中見紅框中有一項(xiàng)信息是“*Access-Control-Allow-Origin:* ”,表示我們已經(jīng)啟用CORS,如果要限制只允許某個域名的請求,可以這樣:
header("Access-Control-Allow-Origin: http://www.dbjr.com.cn");
示例:通過CORS跨域請求數(shù)據(jù)
$.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.'); } });
我們在另一個網(wǎng)站域名下的ajax.php加上這樣的代碼:
header("Access-Control-Allow-Origin: http://www.dbjr.com.cn"); $data = array( 'rand' => $_GET['random'], 'msg' => 'Success' ); echo json_encode($data);
這就實(shí)現(xiàn)了從www.dbjr.com.cn頁面發(fā)起跨域異步請求到域名路徑demo.jb51.net/phpajax/ajax.php,并得到響應(yīng)。
以上所述是小編給大家介紹的PHP處理Ajax請求與Ajax跨域,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- PHP下ajax跨域的解決方案之window.name實(shí)例分析
- PHP ajax跨子域的解決方案之document.domain+iframe實(shí)例分析
- PHP下ajax跨域的解決方案之jsonp實(shí)例分析
- jquery ajax結(jié)合thinkphp的getjson實(shí)現(xiàn)跨域的方法
- PHP中運(yùn)用jQuery的Ajax跨域調(diào)用實(shí)現(xiàn)代碼
- php+mysql+ajax 局部刷新點(diǎn)贊/取消點(diǎn)贊功能(每個賬號只點(diǎn)贊一次)
- Jquery+AJAX實(shí)現(xiàn)無刷新上傳并重命名文件操作示例【PHP后臺接收】
- PHP使用ajax的post方式下載excel文件簡單示例
- PHP Ajax跨域問題解決方案代碼實(shí)例
相關(guān)文章
php根據(jù)數(shù)據(jù)id自動生成編號的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猵hp根據(jù)數(shù)據(jù)id自動生成編號的實(shí)現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10Zend Framework教程之Zend_Db_Table_Row用法實(shí)例分析
這篇文章主要介紹了Zend Framework教程之Zend_Db_Table_Row用法,詳細(xì)講述了Zend_Db_Table_Row的功能,并結(jié)合實(shí)例形式詳細(xì)分析了Zend_Db_Table_Row操作數(shù)據(jù)的相關(guān)技巧,需要的朋友可以參考下2016-03-03微信公眾平臺開發(fā)(五) 天氣預(yù)報(bào)功能開發(fā)
這篇文章主要介紹了微信公眾平臺開發(fā)(五) 天氣預(yù)報(bào)功能開發(fā) ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12詳細(xì)解讀PHP的Yii框架中登陸功能的實(shí)現(xiàn)
這篇文章主要介紹了詳細(xì)解讀PHP的Yii框架中登陸功能的實(shí)現(xiàn),包括通過cookie實(shí)現(xiàn)自動登錄的功能,需要的朋友可以參考下2015-08-08Thinkphp通過一個入口文件如何區(qū)分移動端和PC端
這篇文章主要介紹了Thinkphp通過一個入口文件區(qū)分移動端和PC端的方法,需要的的朋友參考下吧2017-04-04destoon調(diào)用企業(yè)會員公司形象圖片的實(shí)現(xiàn)方法
這篇文章主要介紹了destoon調(diào)用企業(yè)會員公司形象圖片的實(shí)現(xiàn)方法,非常實(shí)用,需要的朋友可以參考下2014-08-08