国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

詳解js跨域請求的兩種方式,支持post請求

2024-05-06 15:34:36
字體:
來源:轉載
供稿:網友

JSONP實現(xiàn)跨域

常用的jquery實現(xiàn)跨域調用

$.ajax({  url: "http://127.0.0.1/~chenjiebin/mycode/php/crossdomain/index.php",  dataType: "jsonp",  jsonp: "callback",  context: document.body,  success: function(data) {    console.log(data);  }});

這個調用實際上的實現(xiàn)原理是
在網頁中構造一個script標簽,將src設置為對應的url,并增加上相應的callback參數(shù),形如如下格式:

<script src="http://127.0.0.1/~chenjiebin/mycode/php/crossdomain/index.php?callback=jQuery211018970995225637144_1465350372062&_=1465350372063"></script>

請求的服務端代碼如下:

$data   = json_encode(array("id" => "1", "name" => "tom"));$callback = $_GET["callback"];echo $callback . "(" . $data . ")";

實際上最后返回的內容就是一段js代碼:

jQuery211018970995225637144_1465350372062({"id":"1","name":"tom"})

當瀏覽器獲取到該段js代碼后就會執(zhí)行這個函數(shù),從而實現(xiàn)回調ajax請求時設置的success方法。

jsonp實現(xiàn)的缺點

了解了原理后,就知道jsonp實現(xiàn)的跨域方式不支持post請求,只能支持get請求。但是如果需要支持post請求該怎么辦呢?下面談下服務器端設置的方式。

服務端設置支持跨域

主要是Access-Control-Allow-Origin頭參數(shù),該參數(shù)用來指定允許哪個來源的域請求。服務端代碼如下:

// 表示支持所有來源的域進行請求// 實際在操作過程中可以設置為指定域header('Access-Control-Allow-Origin:*');$data = json_encode(array("id" => "1", "name" => "tom"));echo $data;

對應的js代碼:

$.ajax({  type: "POST",  url: "http://127.0.0.1/~chenjiebin/mycode/php/crossdomain/header.php",  dataType: "json",  success: function(data) {    console.log(data);  }});

可以支持post請求。

小結

實際上個人并不是特別喜歡用跨域請求的方式,可能會帶來一些不可預見的安全問題。比較習慣的方式通過本域下的服務端和跨域的源服務器進行交互。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 银川市| 蒙阴县| 凤台县| 西安市| 盐城市| 昌江| 松江区| 铜川市| 兴山县| 仪陇县| 兴义市| 济阳县| 桦川县| 额尔古纳市| 龙海市| 新宁县| 吉林市| 甘洛县| 新巴尔虎左旗| 万年县| 古浪县| 平泉县| 寿宁县| 叶城县| 察哈| 昭苏县| 新和县| 皮山县| 桂阳县| 谷城县| 桂林市| 新郑市| 常熟市| 昌黎县| 滕州市| 株洲县| 栾城县| 修水县| 美姑县| 安阳县| 大连市|