亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解js跨域請(qǐng)求的兩種方式,支持post請(qǐng)求

 更新時(shí)間:2018年05月05日 12:45:51   投稿:mdxy-dxy  
原先一直以為要實(shí)現(xiàn)跨域請(qǐng)求只能用jsonp,只能支持GET請(qǐng)求,后來了解到使用POST請(qǐng)求也可以實(shí)現(xiàn)跨域,但是需要在服務(wù)器增加Access-Control-Allow-Origin和Access-Control-Allow-Headers頭,下面說明下兩個(gè)不同的方法實(shí)現(xiàn)的方式和原理。

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)行交互。

相關(guān)文章

  • 淺析JS運(yùn)動(dòng)

    淺析JS運(yùn)動(dòng)

    這篇文章主要介紹了JS運(yùn)動(dòng)的實(shí)現(xiàn)原理,介紹了JS多種運(yùn)動(dòng)方式,希望大家仔細(xì)學(xué)習(xí),感興趣的小伙伴們可以參考一下
    2015-12-12
  • 微信小程序自定義可滾動(dòng)的彈出框

    微信小程序自定義可滾動(dòng)的彈出框

    這篇文章主要為大家詳細(xì)介紹了微信小程序自定義可滾動(dòng)的彈出框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 淺談JavaScript中你可能不知道URL構(gòu)造函數(shù)的屬性

    淺談JavaScript中你可能不知道URL構(gòu)造函數(shù)的屬性

    這篇文章主要介紹了淺談JavaScript中你可能不知道URL構(gòu)造函數(shù)的屬性,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • JavaScript容錯(cuò)例外處理

    JavaScript容錯(cuò)例外處理

    程序開發(fā)中,編程人員經(jīng)常要面對(duì)的是如何編寫代碼來響應(yīng)錯(cuò)誤事件的發(fā)生,即例外處理(exception handlers)。
    2008-06-06
  • JavaScript實(shí)現(xiàn)請(qǐng)求服務(wù)端接口方法詳解

    JavaScript實(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
  • JS觸發(fā)服務(wù)器控件的單擊事件(詳解)

    JS觸發(fā)服務(wù)器控件的單擊事件(詳解)

    下面小編就為大家?guī)硪黄狫S觸發(fā)服務(wù)器控件的單擊事件(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-08-08
  • javascript實(shí)用方法總結(jié)

    javascript實(shí)用方法總結(jié)

    本文這里給大家總結(jié)了一些常用的javascript方法,都是些短小精悍的小代碼,提高執(zhí)行效率,這里推薦給大家。
    2015-02-02
  • 整理關(guān)于Bootstrap模態(tài)彈出框的慕課筆記

    整理關(guān)于Bootstrap模態(tài)彈出框的慕課筆記

    這篇文章主要為大家整理了關(guān)于Bootstrap模態(tài)彈出框的慕課筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • js實(shí)現(xiàn)樓層效果的簡(jiǎn)單實(shí)例

    js實(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)文字功能

    如何基于小程序?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

最新評(píng)論