詳解js跨域請求的兩種方式,支持post請求
JSONP實現(xiàn)跨域
常用的jquery實現(xiàn)跨域調(diào)用
$.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);
}
});
這個調(diào)用實際上的實現(xiàn)原理是
在網(wǎng)頁中構(gòu)造一個script標(biāo)簽,將src設(shè)置為對應(yīng)的url,并增加上相應(yīng)的callback參數(shù),形如如下格式:
<script src="http://127.0.0.1/~chenjiebin/mycode/php/crossdomain/index.php?callback=jQuery211018970995225637144_1465350372062&_=1465350372063"></script>
請求的服務(wù)端代碼如下:
$data = json_encode(array("id" => "1", "name" => "tom"));
$callback = $_GET["callback"];
echo $callback . "(" . $data . ")";
實際上最后返回的內(nèi)容就是一段js代碼:
jQuery211018970995225637144_1465350372062({"id":"1","name":"tom"})
當(dāng)瀏覽器獲取到該段js代碼后就會執(zhí)行這個函數(shù),從而實現(xiàn)回調(diào)ajax請求時設(shè)置的success方法。
jsonp實現(xiàn)的缺點
了解了原理后,就知道jsonp實現(xiàn)的跨域方式不支持post請求,只能支持get請求。但是如果需要支持post請求該怎么辦呢?下面談下服務(wù)器端設(shè)置的方式。
服務(wù)端設(shè)置支持跨域
主要是Access-Control-Allow-Origin頭參數(shù),該參數(shù)用來指定允許哪個來源的域請求。服務(wù)端代碼如下:
// 表示支持所有來源的域進行請求
// 實際在操作過程中可以設(shè)置為指定域
header('Access-Control-Allow-Origin:*');
$data = json_encode(array("id" => "1", "name" => "tom"));
echo $data;
對應(yīng)的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請求。
小結(jié)
實際上個人并不是特別喜歡用跨域請求的方式,可能會帶來一些不可預(yù)見的安全問題。比較習(xí)慣的方式通過本域下的服務(wù)端和跨域的源服務(wù)器進行交互。
- Nodejs Post請求報socket hang up錯誤的解決辦法
- nodejs實現(xiàn)HTTPS發(fā)起POST請求
- Angularjs中$http以post請求通過消息體傳遞參數(shù)的實現(xiàn)方法
- 輕松創(chuàng)建nodejs服務(wù)器(10):處理POST請求
- JSP、Servlet中g(shù)et請求和post請求的區(qū)別總結(jié)
- JS獲取url參數(shù),JS發(fā)送json格式的POST請求方法
- linux shell中curl 發(fā)送post請求json格式問題的處理方法
- nodejs使用http模塊發(fā)送get與post請求的方法示例
- java模擬post請求發(fā)送json的例子
- JS實現(xiàn)使用POST方式發(fā)送請求
相關(guān)文章
淺談JavaScript中你可能不知道URL構(gòu)造函數(shù)的屬性
這篇文章主要介紹了淺談JavaScript中你可能不知道URL構(gòu)造函數(shù)的屬性,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
JavaScript實現(xiàn)請求服務(wù)端接口方法詳解
這篇文章主要介紹了JavaScript實現(xiàn)請求服務(wù)端接口方法,JavaScript?中請求服務(wù)端接口的代碼實現(xiàn)可能會因為使用的方法而有所不同,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01
整理關(guān)于Bootstrap模態(tài)彈出框的慕課筆記
這篇文章主要為大家整理了關(guān)于Bootstrap模態(tài)彈出框的慕課筆記,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
如何基于小程序?qū)崿F(xiàn)發(fā)送語音消息及轉(zhuǎn)文字功能
最近為小程序增加語音識別轉(zhuǎn)文字的功能,坑路不斷,特此記錄,下面這篇文章主要給大家介紹了關(guān)于如何基于小程序?qū)崿F(xiàn)發(fā)送語音消息及轉(zhuǎn)文字功能的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11

