日韩精品成人无码专区免费-国产99久久久久久免费看-国产精品丝袜久久久久久不卡-国产精品无码一区二区三区

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

發(fā)布時間:2024-06-05 點擊:130
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']默認是xmlhttprequest,$_server['http_x_requested_with']也可以自定義創(chuàng)建的,使用xmlhttprequest.setrequestheader(name,value)。
相關(guān)學習推薦:php編程(視頻)
示例:前端頁面發(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.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返回。當然,我們也可以自定義回調(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的頁面上要點數(shù)據(jù),通常情況由于同源策略,這種請求是不允許的,瀏覽器也會返回“源不匹配”的錯誤,所以就有了“跨域”這個說法。但是我們也有解決辦法,我們可以再b.com的頁面header信息中增加一行代碼:
header("access-control-allow-origin: *");當我們設(shè)置的header為以上信息時,任意一個請求過來之后服務(wù)端我們都可以進行處理和響應(yīng),那么在調(diào)試工具中可以看到其頭信息設(shè)置,其中見紅框中有一項信息是“*access-control-allow-origin:* ”,表示我們已經(jīng)啟用cors,如果要限制只允許某個域名的請求,可以這樣:
header("access-control-allow-origin: https://www.jb51.net");示例:通過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: https://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)。
相關(guān)視頻推薦:php編程從入門到精通

創(chuàng)業(yè)公司在選擇域名時應(yīng)該避免哪些錯誤
新手想要國際域名怎么選?有什么好的方向?
該怎樣降級營銷型網(wǎng)站因變更域名帶來的影響
已經(jīng)跟客戶溝通請幫重新提交管局審核
有哪些好用的在線播放器 免費的在線播放器合集推薦
1核1g云服務(wù)器多少錢
【百寶云】私有云-幫電商企業(yè)搭建中臺管理系統(tǒng)
百度進軍互聯(lián)網(wǎng)金融推百度股市通 啟用二級域名