欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

    <abbr id="cs86x"><var id="cs86x"></var></abbr>
    <bdo id="cs86x"></bdo>

    <thead id="cs86x"><progress id="cs86x"><pre id="cs86x"></pre></progress></thead>

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

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

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

    相關(guān)文章

    • 淺析JS運動

      淺析JS運動

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

      微信小程序自定義可滾動的彈出框

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

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

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

      JavaScript容錯例外處理

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

      JavaScript實現(xiàn)請求服務(wù)端接口方法詳解

      這篇文章主要介紹了JavaScript實現(xiàn)請求服務(wù)端接口方法,JavaScript?中請求服務(wù)端接口的代碼實現(xiàn)可能會因為使用的方法而有所不同,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
      2023-01-01
    • JS觸發(fā)服務(wù)器控件的單擊事件(詳解)

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

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

      javascript實用方法總結(jié)

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

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

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

      js實現(xiàn)樓層效果的簡單實例

      下面小編就為大家?guī)硪黄猨s實現(xiàn)樓層效果的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
      2016-07-07
    • 如何基于小程序?qū)崿F(xiàn)發(fā)送語音消息及轉(zhuǎn)文字功能

      如何基于小程序?qū)崿F(xiàn)發(fā)送語音消息及轉(zhuǎn)文字功能

      最近為小程序增加語音識別轉(zhuǎn)文字的功能,坑路不斷,特此記錄,下面這篇文章主要給大家介紹了關(guān)于如何基于小程序?qū)崿F(xiàn)發(fā)送語音消息及轉(zhuǎn)文字功能的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
      2022-11-11

    最新評論