PHP判斷是否為Ajax請求
##我們知道,在發送ajax請求的時候,可以透過XMLHttpRequest這個對象,建立自訂的header頭訊息, 在jquery框架中,對於透過它的$.ajax, $.get, 或者$.post方法請求網頁內容時,它會傳遞一個HTTP_X_REQUESTED_WITH的參數,php中就是在header一層判斷是否是ajax請求,對應的根據$_SERVER['HTTP_X_REQUESTED_WITH']判斷。一般情況下$_SERVER
['HTTP_X_REQUESTED_WITH']預設是
XMLHttpRequest,$_SERVER['HTTP_X_REQUESTED_WITH']也可以自訂建立的,使用
XMLHttpRequest.setRequestHeader( value)。
相關學習推薦:#範例:前端頁面傳送普通的ajax請求給後端test. php。php程式設計(影片)
$.ajax({ type: "GET", url: 'test.php', success: function(data) { console.log(data); } });服務端test.php可以判斷該請求是不是Ajax非同步請求,然後根據業務需求做出回應的回應。 以下是服務端test.php的簡單驗證是否為ajax請求的程式碼:
function isAjax() { return @$_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest' ? true : false; } if (isAjax()) { echo 'Ajax Request Success.'; } else { echo 'No.'; }
Ajax發起JSONP跨域請求
#我們透過jQuery的JSONP方式可以實現跨域ajax請求,服務端php也需要做出對應的處理,也就是說php這邊必須和前端頁面按照一定的格式請求和回傳資料。 範例:前端頁面發起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.'); } });我們會發現,ajax請求參數中有dataType: "jsonp" 和jsonp: "callback" ,這就顯示了我要請求的是jsonp,並且會有回呼callback回傳。當然,我們也可以自訂回呼函數,如jsonpCallback:"success_jsonpCallback"也可以簡單的寫成:
jQuery.getJSON('http://demo.jb51.net/phpajax/jsonp.php?callback=?",{ random: Math.random() }, function(data){ console.log(data); });php後端服務程式碼可以這樣寫(注意輸出回傳的格式) :
$data = array( 'rand' => $_GET['random'], 'msg' => 'Success' ); echo $_GET['callback'].'('.json_encode($data).')';
Ajax跨域請求:CORS
CORS,又稱跨域資源共享,英文全稱Cross-Origin Resource Sharing。假設我們想使用Ajax從a.com的頁面上向b.com的頁面上要點數據,通常情況由於同源策略,這種請求是不允許的,瀏覽器也會返回“源不匹配”的錯誤,所以就有了「跨域」這個說法。但是我們也有解決辦法,我們可以再b.com的頁面header訊息中增加一行程式碼:header("Access-Control-Allow-Origin: *");當我們設定的header為以上資訊時,任一請求過來之後服務端我們都可以進行處理和響應,那麼在調試工具中可以看到其頭信息設置,其中見紅框中有一項信息是“*Access-Control-Allow-Origin:* ”,表示我們已經啟用CORS,如果要限制只允許某個網域的請求,可以這樣:
header("Access-Control-Allow-Origin: https://www.jb51.net");範例:透過CORS跨網域請求資料
$.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.'); } });我們在另一個網站網域下的ajax.php加上這樣的程式碼:
header("Access-Control-Allow-Origin: https://www.jb51.net"); $data = array( 'rand' => $_GET['random'], 'msg' => 'Success' ); echo json_encode($data);這實現了從www.jb51.net頁面發起跨域非同步請求到網域路徑demo.jb51.net/phpajax/ajax.php,並且回應。
相關影片推薦:#
以上是解決PHP處理Ajax請求與Ajax跨域問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!