首頁 >後端開發 >php教程 >PHP處理Ajax請求與Ajax跨域問題詳解

PHP處理Ajax請求與Ajax跨域問題詳解

墨辰丷
墨辰丷原創
2018-05-25 15:02:371453瀏覽

這篇文章主要介紹了PHP處理Ajax請求與Ajax跨域問題的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

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。

$.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: http://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: http://www.jb51.net");
$data = array(
  'rand' => $_GET['random'],
  'msg' => 'Success'
);
echo json_encode($data);
####### ##這實現了從www.jb51.net頁面發起跨域非同步請求到網域路徑demo.jb51.net/phpajax/ajax.php,並且得到回應。 ######以上就是本文的全部內容,希望對大家的學習有所幫助。 ###############相關推薦:#########如何用vue設定proxyTable參數###跨網域########### ######服務端設定實作AJAX###跨網域###請求################解決ajax###跨網域###請求資料cookie遺失問題###########################

以上是PHP處理Ajax請求與Ajax跨域問題詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn