午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

PHP處理Ajax請求與Ajax跨域

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

PHP判斷是否為Ajax請求

我們知道,在發(fā)送ajax請求的時候,可以通過XMLHttpRequest這個對象,創(chuàng)建自定義的header頭信息, 在jquery框架中,對于通過它的$.ajax, $.get, 或者$.post方法請求網頁內容時,它會向服務器傳遞一個HTTP_X_REQUESTED_WITH的參數(shù),php中就是在header一層判斷是否是ajax請求,對應的根據(jù)$_SERVER[’HTTP_X_REQUESTED_WITH’]判斷。一般情況下$_SERVER[’HTTP_X_REQUESTED_WITH’]默認是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); }});

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

以下是服務端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請求,服務端php也需要做出相應的處理,也就是說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,并且會有回調callback返回。當然,我們也可以自定義回調函數(shù),如 jsonpCallback:'success_jsonpCallback'

還可以簡單的寫成:

jQuery.getJSON(’http://demo.helloweba.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的頁面上要點數(shù)據(jù),通常情況由于同源策略,這種請求是不允許的,瀏覽器也會返回“源不匹配”的錯誤,所以就有了“跨域”這個說法。但是我們也有解決辦法,我們可以再b.com的頁面header信息中增加一行代碼:

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

當我們設置的header為以上信息時,任意一個請求過來之后服務端我們都可以進行處理和響應,那么在調試工具中可以看到其頭信息設置,其中見紅框中有一項信息是“*Access-Control-Allow-Origin:* ”,表示我們已經啟用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.’); }});

我們在另一個網站域名下的ajax.php加上這樣的代碼:

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

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

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

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

標簽: PHP
相關文章:
主站蜘蛛池模板: 91精选国产| 国产suv精品一区二区33 | 欧美 日韩 综合 | 91精品国产综合久久精品图片 | 日韩一级在线播放 | 亚洲一区二区视频在线 | 日本一区二区三区四区五区六区 | 狠狠热视频 | 欧美午夜一区 | 超碰狠狠 | 成年人在线视频 | 国产 日韩 欧美 成人 | 国产成人av一区二区三区 | 成人在线激情视频 | 欧美日韩在线网站 | 亚洲高潮av | 国产精品久久久久久无人区 | 中文天堂在线资源 | 久久网站免费 | 久久久观看 | 欧美顶级毛片在线播放 | 91精品国产麻豆 | 久久人人视频 | 婷婷色中文字幕 | 天天干天天草 | 山村性事乱淫1一7 | 欧美三级视频在线 | www.av在线播放 | 都市激情中文字幕 | 超碰在线98| 亚洲国产91 | 午夜啊啊啊| 成人免费一级视频 | 午夜影院免费体验区 | 日韩综合区 | sihu在线| 美女av在线免费观看 | 天天综合网久久综合网 | 在线观看黄色av | 国产精品不卡在线 | 亚洲一区久久久 |