亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

一看就懂:jsonp詳解

2019-11-20 12:23:03
字體:
來源:轉載
供稿:網友

json相信大家都用的多,jsonp我就一直沒有機會用到,但也經常看到,只知道是“用來跨域的”,一直不知道具體是個什么東西。今天總算搞明白了。下面一步步來搞清楚jsonp是個什么玩意。

同源策略

首先基于安全的原因,瀏覽器是存在同源策略這個機制的,同源策略阻止從一個源加載的文檔或腳本獲取或設置另一個源加載的文檔的屬性??雌饋聿恢朗裁匆馑迹瑢嵺`一下就知道了。

1、隨便建兩個網頁

一個端口是2698,一個2701,按照定義它們是不同源的。

2.用jQuery發起不同源的請求
在2698端口的網頁上添加一個按鈕,Click事件隨便發起兩個向端口為2701域的請求。

復制代碼 代碼如下:

$("#getOtherDomainThings").click(function () {
    $.get("http://localhost:2701/Scripts/jquery-1.4.4.min.js", function (data) {
        console.log(data)
    })

    $.get("http://localhost:2701/home/index", function (data) {
        console.log(data)
    })
})


根據同源策略,很明顯會悲劇了。瀏覽器會阻止,根本不會發起這個請求。(not allowed by Access-Control-Allow-Origin)

OK,原來jsonp是要解決這個問題的。

script標簽的跨域能力
不知道大家知不知道CDN這個東西,例如微軟的CDN,使用它,我們的網頁可以不提供jQuery,由微軟的網站幫我們提供:

復制代碼 代碼如下:

<script src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-1.8.0.js" type="text/javascript"></script>

回到我們的2698端口的網頁,上面我們在Click事件里有一個對2701端口域的jQuery文件的請求,這次使用script標簽來請求。
復制代碼 代碼如下:

<script type="text/javascript" src="http://localhost:2701/Scripts/jquery-1.4.4.min.js"></script>

當然,200,OK了

同樣是端口2698的網頁發起對2701域的請求,放在script里設置scr屬性的OK了,另一個方式就悲劇。利用script的跨域能力,這就是jsonp的基礎。

利用script獲取不同源的json
既然它叫jsonp,很明顯目的還是json,而且是跨域獲取。根據上面的分析,很容易想到:利用js構造一個script標簽,把json的url賦給script的scr屬性,把這個script插入到dom里,讓瀏覽器去獲取。實踐:

復制代碼 代碼如下:

function CreateScript(src) {
    $("<script><//script>").attr("src", src).appendTo("body")
}

添加一個按鈕事件來測試一下:
復制代碼 代碼如下:

$("#getOtherDomainJson").click(function () {
    $.get('http://localhost:2701/home/somejson', function (data) {
        console.log(data)
    })
})

首先,第一個瀏覽器,http://localhost:2701/home/somejson這個Url的確是存在一個json的,而且在 2698網頁上用script標簽來請求這個2701這個Url也是200OK的,但是最下面報js語法錯誤了。原來用script標簽加載完后,會立即 把響應當js去執行,很明顯{"Email":"zhww@outlook.com","Remark":"我來自遙遠的東方"}不是合法的js語句。

利用script獲取異域的jsonp

顯然,把上面的json放到一個回調方法里是最簡單的方法。例如,變成這樣:

如果存在jsonpcallback這個方法,那么jsonpcallback({"Email":"zhww@outlook.com","Remark":"我來自遙遠的東方"})就是合法的js語句。

由于服務器不知道客戶端的回調是什么,不可能hard code成jsonpcallback,所以就帶一個QueryString讓客戶端告訴服務端,回調方法是什么,當然,QueryString的key要遵從服務端的約定,上面的是”callback“。

添加回調函數:

復制代碼 代碼如下:

function jsonpcallback(json) {
    console.log(json)
}

把前面的方法稍微改改參數:
復制代碼 代碼如下:

$("#getJsonpByHand").click(function () {
    CreateScript("http://localhost:2701/home/somejsonp?callback=jsonpcallback")
})

200OK,服務器返回jsonpcallback({"Email":"zhww@outlook.com","Remark":"我來自遙遠的 東方"}),我們也寫了jsonpcallback方法,當然會執行。OK順利獲得了json。沒錯,到這里就是jsonp的全部。

利用jQuery獲取jsonp
上面的方式中,又要插入script標簽,又要定義一個回調,略顯麻煩,利用jQuery可以直接得到想要的json數據,同樣是上面的jsonp:

復制代碼 代碼如下:

$("#getJsonpByJquery").click(function () {
    $.ajax({
        url: 'http://localhost:2701/home/somejsonp',
        dataType: "jsonp",
        jsonp: "callback",
        success: function (data) {
            console.log(data)
        }
    })
})

得到的結果跟上面類似。

總結

一句話就是利用script標簽繞過同源策略,獲得一個類似這樣的數據,jsonpcallback是頁面存在的回調方法,參數就是想得到的json。

復制代碼 代碼如下:

jsonpcallback({"Email":"zhww@outlook.com","Remark":"我來自遙遠的東方"})

ADD 原生js:

復制代碼 代碼如下:

<button id="btn">click</button>
<script type="text/javascript">
    function $(str){
        return document.getElementById(str)
    }
    function CreateScript(src) {
        var Scrip=document.createElement('script');
        Scrip.src=src;
        document.body.appendChild(Scrip);
    }
    function jsonpcallback(json) {
            console.log(json);//Object { email="中國", email2="中國222"}
    }
    $('btn').onclick=function(){
      CreateScript("http://localhost:51335/somejson?callback=jsonpcallback")   
    }
</script>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品免费网站| 亚洲国产精品高清久久久| 亚洲一区二区黄| 国产一区二区日韩精品欧美精品| 久久久久国产精品一区| 91精品国产91久久久久久不卡| 亚洲剧情一区二区| 国内精品小视频| 92国产精品视频| 久久亚洲综合国产精品99麻豆精品福利| 久久99青青精品免费观看| 亚洲国产精品yw在线观看| 欧美老女人bb| 91中文字幕在线观看| 色www亚洲国产张柏芝| 久久久久日韩精品久久久男男| www.久久久久| 国产精品高潮呻吟久久av野狼| 97精品伊人久久久大香线蕉| 欧美性猛交xxxx乱大交3| 一级做a爰片久久毛片美女图片| 精品无人区太爽高潮在线播放| 成人亚洲欧美一区二区三区| 亚洲精品网站在线播放gif| 久久影院资源网| 亚洲精品美女在线观看播放| 国产精品久久国产精品99gif| 亚洲老头老太hd| 国产成人精品亚洲精品| 国产日韩欧美另类| 国产一区二区三区在线观看视频| 久久久免费高清电视剧观看| 亚洲一区美女视频在线观看免费| 久久影院资源站| 久久久999成人| 久久精品国产欧美亚洲人人爽| 日韩欧美国产黄色| 亚洲在线www| 色无极亚洲影院| 欧美日韩在线视频一区二区| 日韩av在线网站| 欧美精品激情视频| 68精品国产免费久久久久久婷婷| 热re99久久精品国产66热| 欧美一区在线直播| 色老头一区二区三区在线观看| 这里只有精品在线播放| 国产久一一精品| 成人免费淫片aa视频免费| 国产综合在线观看视频| 中文字幕久热精品在线视频| 欧美性色xo影院| 日韩精品视频免费在线观看| 91国产精品91| 亚洲欧美999| 久久精品视频一| 日韩成人中文字幕| 久久精品这里热有精品| 亚洲人成网站色ww在线| 爽爽爽爽爽爽爽成人免费观看| 国产手机视频精品| www.午夜精品| 国产亚洲欧美另类中文| 国产成人精品在线观看| 久久男人资源视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 性欧美暴力猛交69hd| 最近中文字幕mv在线一区二区三区四区| 亚洲性生活视频在线观看| 国产精品www网站| 精品久久久中文| 日韩精品免费观看| 欧美激情精品久久久久久黑人| 91chinesevideo永久地址| 久久久久久久av| 深夜福利亚洲导航| 亚洲自拍偷拍福利| 美日韩在线视频| 欧美性20hd另类| 欧美日本国产在线| 国产香蕉精品视频一区二区三区| 国产大片精品免费永久看nba| 国产精品久久久久久久久久久久| 清纯唯美亚洲激情| 国产成人精品在线播放| 日韩电影免费观看中文字幕| 久久全球大尺度高清视频| 国产精品久久久久久久久久久新郎| 国产成人精品在线观看| 欧洲成人免费aa| 国产91色在线|免| 亚洲激情在线视频| 欧美性猛交xxxx免费看久久久| 欧美日韩高清在线观看| 欧美国产日韩视频| 亚洲xxxx视频| 亚洲视频国产视频| 亚洲三级av在线| 久久久久国产精品一区| 伦理中文字幕亚洲| 自拍偷拍亚洲精品| 国产精品欧美激情| 国产精品久久久久久影视| 国产午夜精品理论片a级探花| 永久免费精品影视网站| 国产精品黄页免费高清在线观看| 国产精品成人av在线| 亚洲欧洲黄色网| 亚洲精品国产福利| 久久免费视频在线观看| 久久久久久久久久久免费精品| 日本久久精品视频| www国产精品视频| 亚洲国产精品一区二区久| 国产精品偷伦免费视频观看的| 中文字幕视频一区二区在线有码| 国产精品久久久久久久久久久不卡| 亚洲a中文字幕| 亚洲精品999| 欧洲成人在线视频| 欧美亚洲视频在线观看| 欧美在线一级va免费观看| 久久久久久这里只有精品| 日本三级韩国三级久久| 亚洲激情免费观看| 国产精品流白浆视频| 国产日韩中文字幕| 国产69久久精品成人| 亚洲永久免费观看| 日韩中文字幕在线视频播放| 欧美日韩国产成人在线观看| 黑人精品xxx一区一二区| 日本19禁啪啪免费观看www| 国产精品电影久久久久电影网| 中文字幕av一区二区三区谷原希美| 亚洲网站视频福利| 97激碰免费视频| 中文字幕综合一区| 国产精品永久免费观看| 久久国产精品久久久久| 欧美日韩加勒比精品一区| 欧美电影免费观看高清完整| 亚洲精品国精品久久99热一| 国产精品大片wwwwww| 日韩一区二区三区xxxx| 九色精品免费永久在线| 欧美福利视频在线观看| 欧美精品videosex性欧美| 日本中文字幕不卡免费| 亚洲最大av网| 九九久久久久99精品| 日韩视频在线观看免费| 国内精品小视频在线观看| 日韩黄色在线免费观看| 亚洲欧美国产高清va在线播| 免费不卡在线观看av| 91精品国产免费久久久久久| 久久成人精品电影| 国产一区二区三区在线观看视频| 亚洲免费电影在线观看| 国产精品成人免费视频| 国产成人精品午夜| 色偷偷88888欧美精品久久久| 国产亚洲视频在线观看|