日韩精品欧美激情国产一区_中文无码精品一区二区三区在线_岛国毛片AV在线无码不卡_亞洲歐美日韓精品在線_使劲操好爽好粗视频在线播放_日韩一区欧美二区_八戒八戒网影院在线观看神马_亚洲怡红院在线色网_av无码不卡亚洲电影_国产麻豆媒体MDX

PHP處理ajax請求以及ajax跨域問題

時間:2017-02-12 14:57:30 類型:PHP
字號:    

      我們知道前端頁面發(fā)送Ajax到服務(wù)端,服務(wù)端可以判斷請求是否是Ajax請求?而對于跨域的Ajax請求,我們知道通常有jsonp方法,那服務(wù)器PHP該如何處理這些jsonp請求呢?以及如何處理不是jsonp請求的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的簡單驗證是否為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方式可以實現(xiàn)跨域ajax請求,服務(wù)端php也需要做出相應(yīng)的處理,也就是說php這邊必須和前端頁面按照一定的格式請求和返回數(shù)據(jù)。
示例:前端頁面發(fā)起JSONP請求:
$.ajax({ 
    type: "get", 
    data: "random="+Math.random(), 
    url: "http://demo.helloweba.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.helloweba.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的頁面上要點數(shù)據(jù),通常情況由于同源策略,這種請求是不允許的,瀏覽器也會返回“源不匹配”的錯誤,所以就有了“跨域”這個說法。但是我們也有解決辦法,我們可以再b.com的頁面header信息中增加一行代碼:

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

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

header("Access-Control-Allow-Origin: http://www.helloweba.com");

示例:通過CORS跨域請求數(shù)據(jù)

$.ajax({ 
    type: "get", 
    data: "random="+Math.random(), 
    url: "http://demo.helloweba.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.helloweba.com"); 
 
$data = array( 
    'rand' => $_GET['random'], 
    'msg' => 'Success' 
); 
echo json_encode($data);