亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

php語言

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

時間:2024-05-26 00:24:33 php語言 我要投稿
  • 相關(guān)推薦

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

  這篇文章主要介紹了PHP處理Ajax請求與Ajax跨域問題的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下,就跟隨百分網(wǎng)小編一起去了解下吧,想了解更多相關(guān)信息請持續(xù)關(guān)注我們應(yīng)屆畢業(yè)生考試網(wǎng)!

  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。

  ?

  1

  2

  3

  4

  5

  6

  7

  $.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的簡單驗證是否為ajax請求的代碼:

  ?

  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跨域請求

  我們通過jQuery的JSONP方式可以實現(xiàn)跨域ajax請求,服務(wù)端php也需要做出相應(yīng)的處理,也就是說php這邊必須和前端頁面按照一定的格式請求和返回數(shù)據(jù)。

  示例:前端頁面發(fā)起JSONP請求:

  ?

  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.');

  }

  });

  我們會發(fā)現(xiàn),ajax請求參數(shù)中有 dataType: "jsonp" 和 jsonp: "callback" ,這個就表明了我要請求的是jsonp,并且會有回調(diào)callback返回。當(dāng)然,我們也可以自定義回調(diào)函數(shù),如 jsonpCallback:"success_jsonpCallback"

  還可以簡單的寫成:

  ?

  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ù)代碼可以這樣寫(注意輸出返回的格式):

  ?

  1

  2

  3

  4

  5

  $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信息中增加一行代碼:

  ?

  1

  header("Access-Control-Allow-Origin: *");

  當(dāng)我們設(shè)置的header為以上信息時,任意一個請求過來之后服務(wù)端我們都可以進(jìn)行處理和響應(yīng),那么在調(diào)試工具中可以看到其頭信息設(shè)置,其中見紅框中有一項信息是“*Access-Control-Allow-Origin:* ”,表示我們已經(jīng)啟用CORS,如果要限制只允許某個域名的請求,可以這樣:

  ?

  1

  header("Access-Control-Allow-Origin: http://www.jb51.net");

  示例:通過CORS跨域請求數(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.');

  }

  });

  我們在另一個網(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);

  這就實現(xiàn)了從www.jb51.net頁面發(fā)起跨域異步請求到域名路徑demo.jb51.net/phpajax/ajax.php,并得到響應(yīng)。

  以上所述是小編給大家介紹的PHP處理Ajax請求與Ajax跨域,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

【PHP處理Ajax請求與Ajax跨域問題】相關(guān)文章:

基于PHP+Ajax實現(xiàn)表單驗證的詳解03-03

PHP怎么處理密碼08-28

PHP如何使用curl發(fā)送GET和POST請求03-24

PHP如何用curl發(fā)送GET和POST請求03-02

PHP處理密碼的幾種方式實例03-29

php常用的url處理函數(shù)集03-20

PHP中使用cURL實現(xiàn)Get和Post請求的方法12-03

完美解決PHP中文亂碼問題12-06

php字符串截取問題11-17