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