久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

PHP處理Ajax請(qǐng)求與Ajax跨域

瀏覽:101日期:2022-09-11 14:53:54

PHP判斷是否為Ajax請(qǐng)求

我們知道,在發(fā)送ajax請(qǐng)求的時(shí)候,可以通過XMLHttpRequest這個(gè)對(duì)象,創(chuàng)建自定義的header頭信息, 在jquery框架中,對(duì)于通過它的$.ajax, $.get, 或者$.post方法請(qǐng)求網(wǎng)頁內(nèi)容時(shí),它會(huì)向服務(wù)器傳遞一個(gè)HTTP_X_REQUESTED_WITH的參數(shù),php中就是在header一層判斷是否是ajax請(qǐng)求,對(duì)應(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請(qǐng)求給后端test.php。

$.ajax({ type: 'GET', url: ’test.php’, success: function(data) {console.log(data); }});

服務(wù)端test.php可以判斷該請(qǐng)求是不是Ajax異步請(qǐng)求,然后根據(jù)業(yè)務(wù)需求做出響應(yīng)的回應(yīng)。

以下是服務(wù)端test.php的簡(jiǎn)單驗(yàn)證是否為ajax請(qǐng)求的代碼:

function isAjax() { return @$_SERVER[’HTTP_X_REQUESTED_WITH’] == ’XMLHttpRequest’ ? true : false;}if (isAjax()) { echo ’Ajax Request Success.’;} else { echo ’No.’;}

Ajax發(fā)起JSONP跨域請(qǐng)求

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

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

$.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.’); }});

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

還可以簡(jiǎn)單的寫成:

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跨域請(qǐng)求:CORS

CORS,又稱跨域資源共享,英文全稱Cross-Origin Resource Sharing。假設(shè)我們想使用Ajax從a.com的頁面上向b.com的頁面上要點(diǎn)數(shù)據(jù),通常情況由于同源策略,這種請(qǐng)求是不允許的,瀏覽器也會(huì)返回“源不匹配”的錯(cuò)誤,所以就有了“跨域”這個(gè)說法。但是我們也有解決辦法,我們可以再b.com的頁面header信息中增加一行代碼:

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

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

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

示例:通過CORS跨域請(qǐng)求數(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.’); }});

我們?cè)诹硪粋€(gè)網(wǎng)站域名下的ajax.php加上這樣的代碼:

header('Access-Control-Allow-Origin: http://www.helloweba.com');$data = array( ’rand’ => $_GET[’random’], ’msg’ => ’Success’);echo json_encode($data);

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

好了,以上是關(guān)于PHP處理ajax以及跨域的相關(guān)內(nèi)容,大家可以下載源代碼以及參照demo中的在線演示體驗(yàn)下效果。Helloweba.com感謝您的關(guān)注。

來自:http://www.helloweba.com/view-blog-408.html

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 神木县| 临夏市| 罗甸县| 兴文县| 黔南| 普格县| 凯里市| 镇原县| 揭西县| 民权县| 巨鹿县| 鹿泉市| 乡城县| 奉贤区| 彭阳县| 双桥区| 垣曲县| 定结县| 土默特左旗| 崇左市| 阳高县| 津市市| 永修县| 元阳县| 平罗县| 奈曼旗| 濮阳县| 三亚市| 独山县| 三门峡市| 仁寿县| 潼关县| 老河口市| 舞钢市| 新蔡县| 邵东县| 台南市| 基隆市| 泰州市| 澳门| 广州市|