JSONP跨域

1.瀏覽器的同源策略

  • 同源策略限制了從同一個源加載的文檔或腳本如何與來自另一個源的資源進行交互论颅。這是一個用于隔離潛在惡意文件的重要安全機制设江。

2.一個源的定義
如果兩個頁面的協(xié)議,端口和域名都相同,則兩個頁面具有相同的源株依,這就是同源。
http://www.example.com/dir/page.html這個網(wǎng)址延窜,協(xié)議是http://恋腕,域名是www.example.com,端口是80(默認端口可以省略)逆瑞。它的同源情況如下荠藤。

  • http://www.example.com/dir2/other.html:同源
  • http://example.com/dir/other.html:不同源(域名不同)
  • http://v2.www.example.com/dir/other.html:不同源(域名不同)
  • http://www.example.com:81/dir/other.html:不同源(端口不同)

參考文章


同源政策規(guī)定,AJAX請求只能發(fā)給同源的網(wǎng)址获高,否則就報錯哈肖。


JSONP實現(xiàn)跨域訪問數(shù)據(jù)

JSONP(JSON with Padding)是JSON的一種“使用模式”
由于同源策略,一般來說位于 server1.example.com 的網(wǎng)頁無法與不是server1.example.com的服務器溝通念秧,而 HTML<script>元素是一個例外淤井。

ajax請求受同源策略影響,不允許進行跨域請求

而script標簽src屬性中的鏈接卻可以訪問跨域的js腳本摊趾,利用這個特性币狠,服務端不再返回JSON格式的數(shù)據(jù),而是返回一段調(diào)用某個函數(shù)的js代碼砾层,在src中進行了調(diào)用漩绵,這樣實現(xiàn)了跨域。

JSONP是服務器與客戶端跨源通信的常用方法肛炮。最大特點就是簡單適用止吐,老式瀏覽器全部支持宝踪,服務器改造非常小。

JSONP的基本思想是祟印,動態(tài)創(chuàng)建一個<script>元素肴沫,script元素發(fā)送請求不熟同源政策的限制,只能發(fā)送get請求蕴忆。服務器收到請求后颤芬,將數(shù)據(jù)放在一個指定名字的回調(diào)函數(shù)里傳回來。

<script>//SRL server rendered javascript
        button.addEventListener('click', (e) => {
            //動態(tài)創(chuàng)建script
            var script = document.createElement('script')
            let functionName='blog1'+parseInt(Math.random()*100000,10)
            
            //callback
            window[functionName]=function(result){
                if(result==='success'){
                    amount.innerText=amount.innerText-1
                }else{} 
            }
            //發(fā)送請求
            script.src = 'http://feile.com/pay?callback='+functionName
            document.body.appendChild(script)
            
            script.onload = function (e) {
                // debugger
                e.currentTarget.remove()
                delete window[functionName]
            }
            script.onerror = function (e) {
                alert('fail')
                e.currentTarget.remove()
                delete window[functionName]
            }
        })
    </script>
    

上面的代碼通過動態(tài)創(chuàng)建添加script元素套鹅,向服務器發(fā)送請求站蝠,查詢字符串必須有callback參數(shù),用來指定回調(diào)函數(shù)的名字卓鹿。

response.write(`${query.callback}.call(undefined,'success')`)

服務器收到這個請求以后菱魔,會將數(shù)據(jù)放在回調(diào)函數(shù)的參數(shù)位置返回。這時只要瀏覽器定義了對應的回調(diào)函數(shù)吟孙,該函數(shù)就會立即被調(diào)用澜倦。

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市杰妓,隨后出現(xiàn)的幾起案子藻治,更是在濱河造成了極大的恐慌,老刑警劉巖巷挥,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件桩卵,死亡現(xiàn)場離奇詭異,居然都是意外死亡倍宾,警方通過查閱死者的電腦和手機雏节,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來高职,“玉大人钩乍,你說我怎么就攤上這事≌浚” “怎么了寥粹?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長产禾。 經(jīng)常有香客問我排作,道長,這世上最難降的妖魔是什么亚情? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任妄痪,我火速辦了婚禮,結(jié)果婚禮上楞件,老公的妹妹穿的比我還像新娘衫生。我一直安慰自己裳瘪,他們只是感情好,可當我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布罪针。 她就那樣靜靜地躺著彭羹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪泪酱。 梳的紋絲不亂的頭發(fā)上派殷,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機與錄音墓阀,去河邊找鬼毡惜。 笑死,一個胖子當著我的面吹牛斯撮,可吹牛的內(nèi)容都是我干的经伙。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼勿锅,長吁一口氣:“原來是場噩夢啊……” “哼帕膜!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起溢十,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤垮刹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后茶宵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體危纫,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡宗挥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年乌庶,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片契耿。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡瞒大,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出搪桂,到底是詐尸還是另有隱情透敌,我是刑警寧澤,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布踢械,位于F島的核電站酗电,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏内列。R本人自食惡果不足惜撵术,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望话瞧。 院中可真熱鬧嫩与,春花似錦寝姿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至处坪,卻和暖如春根资,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背同窘。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工嫂冻, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人塞椎。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓桨仿,卻偏偏與公主長得像,于是被迫代替她去往敵國和親案狠。 傳聞我的和親對象是個殘疾皇子服傍,可洞房花燭夜當晚...
    茶點故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)骂铁,斷路器吹零,智...
    卡卡羅2017閱讀 134,657評論 18 139
  • 瀏覽器安全的基石是“同源政策”(same-origin policy)。很多開發(fā)者都知道這一點拉庵,但了解得不全面灿椅。 ...
    許先生__閱讀 286評論 0 1
  • 1: 什么是同源策略 最初,它的含義是指钞支,A網(wǎng)頁設置的 Cookie茫蛹,B網(wǎng)頁不能打開,除非這兩個網(wǎng)頁"同源",所謂...
    好奇而已閱讀 300評論 0 0
  • <!DOCTYPE html> div>span{display: block;} // ...
    戰(zhàn)神飄雪閱讀 581評論 0 0
  • IMBAIZEXI閱讀 68評論 0 1