一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

JSONP的應用

  先前因為沒工作需要,不存在需要跨域訪問的應用,一直沒接觸過JSONP,只是了解個大概意思,即是插入一個SCRIPT標簽,設置src,讓瀏覽器加載并自動運行,但具體怎么過程,有什么常見的約定等等不甚了解,今天有機會接觸了,具體說一下.

  1. 其實JSONP也是一個”hack”應用

  由于以前的應用沒現在這么復雜,跨域訪問瀏覽器端沒提供標準的方法(可能那時還根本沒考慮過..),當各種應用不斷的豐富之后,需求也隨之而來了,既然需求來了,但瀏覽器沒提供直接的實現,此時就只能根據已有功能,玩些雕蟲小技,待轉幾個彎,兜幾個圈之后,JSONP就出來了.

  2. hack的背后實現

  瀏覽器加載標簽的靜態資源是可以跨域訪問的,如常見的 link:href, script:src,img:src等等,沒有安全限制,可直接訪問,JSONP正是利用了這個特點,加載不同域上的腳本文件.

  待把腳本script標簽插入DOM上的head標簽內,并設置好src屬性時,瀏覽器就開始加載腳本,腳本下載完后直接運行返回的文本內容.

  3. 我們需要的是數據而非源碼

  hack的過程已經了解,但目前為止作用不大,因為瀏覽器連接返回后獲得資源就是JavaScript源碼,并會立即執行這些源碼,你無法異想天開的將這文本放到一個可控的eval里運行之后獲得結果.假如這源碼是任意的,那運行過程根本無法控制,而我們需要的是數據,而非源碼!
  要想控制這些源碼,獲得腳本運行的控制權,把源碼轉換成我們需要的數據,就得有個約定.

  4. 普遍的相關約定
  既然瀏覽器一定會自動執行返回的腳本這個客觀事實改變不了,我們可以在返回的文本上做點處理,和服務器端作個約定,把個已在存在的回調函數寫在外面,再把數據當作參數傳遞,當瀏覽器運行返回源碼的時候,將調用這個回調函數,這樣,控制權又從瀏覽器傳回到我們的手中,數據即參數,也有了,可以為所欲為.
  這過程中回調函數的名稱是要確定的,通常是在發起前把回調函數名稱以提交參數的形式寫在URL中,服務器再從提交參數中把這回調函數名稱輸出到客戶端.

  如,存在一個全局回調函數 function jsonp_callback(data){ alert(data.a); }

  發起時 : jsonp.connect(‘http://www.example.com/getdata.php?callback=jsonp_callback’);

  //
  在服務器端發現這個callback參數值為jsonp_callback,將輸出類似的文本

  jsonp_callback( /**數據*/{a:’b'} );

  瀏覽器端請求返回后將立即運行 jsonp_callback( /**數據*/{a:’b'} );

it知識庫JSONP的應用,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 成年人激情网站 | 久久91av | 91麻豆精品国产 | 美女扒开下面无遮挡免费视频 | 午夜视频在线观看网站 | 国产三级麻豆 | 国产熟睡乱子伦视频 | 国产精品亚洲国产三区 | 久久久综合网 | 久久er99热精品一区二区 | 亚洲五月综合 | 亚洲一区亚洲二区亚洲三区 | 九色国产在视频线精品视频 | 国产免费一区二区三区最新 | 日色网| 国产香蕉久久精品综合网 | 国产一区二区视频免费 | 一级做a爰性色毛片免费 | 国模私拍福利一区二区 | 在线国产二区 | 91精品国产色综合久久不卡蜜 | 性色a v 一区 | 91精品国产综合久久福利 | baoyu777永久免费视频 | 久夜色精品国产一区二区三区 | 91黄色在线观看 | 伊人狠狠 | 国产精品jlzz视频 | 无遮挡毛片a级武则天 | 国产精品视频一区二区噜噜 | 高清一区高清二区视频 | 91系列在线观看 | 在线成人亚洲 | 东日韩二三区 | 福利毛片 | 国产精品毛片va一区二区三区 | 伊人狠狠| 久久男女| 91热视频在线观看 | 久久综合免费视频 | 国产自线一二三四2021 |