久久无码中文字幕_日韩精品无码一本二本三_久久精品呦女暗网_欧美一级夜夜爽_久久精品国产99久久99久久久

03
2018/05

輕松搞定JSONP跨域請求-jsonp詳解

發(fā)布時間:2018-05-03 09:17:15
發(fā)布者:liyongxing
瀏覽量:
0

json相信大家都用的多,jsonp我就一直沒有機會用到,但也經(jīng)??吹剑恢朗恰坝脕砜缬虻摹保恢辈恢谰唧w是個什么東西。今天總算搞明白了。下面一步步來搞清楚jsonp是個什么玩意。

同源策略

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

1.隨便建兩個網(wǎng)頁

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

image_thumb4

2.用jQuery發(fā)起不同源的請求

在2698端口的網(wǎng)頁上添加一個按鈕,Click事件隨便發(fā)起兩個向端口為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)
    })
})

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


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

script標(biāo)簽的跨域能力

不知道大家知不知道CDN這個東西,例如微軟的CDN,使用它,我們的網(wǎng)頁可以不提供jQuery,由微軟的網(wǎng)站幫我們提供:

回到我們的2698端口的網(wǎng)頁,上面我們在Click事件里有一個對2701端口域的jQuery文件的請求,這次使用script標(biāo)簽來請求。

當(dāng)然,200,OK了

image_thumb15

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

利用script獲取不同源的json

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

function CreateScript(src) {
    $("