国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

分享JavaScript的跨域共享的方法

開發 前端
本文介紹的是javascript的跨域共享的方法,希望對你有幫助,一起來看。

在客戶端編程語言中,如javascript和ActionScript,同源策略是一個很重要的安全理念,它在保證數據的安全性方面有著重要的意義。同源策略規定跨域之間的腳本是隔離的,一個域的腳本不能訪問和操作另外一個域的絕大部分屬性和方法。那么什么叫相同域,什么叫不同的域呢?

同源策略

在客戶端編程語言中,如javascript和ActionScript,同源策略是一個很重要的安全理念,它在保證數據的安全性方面有著重要的意義。

同源策略規定跨域之間的腳本是隔離的,一個域的腳本不能訪問和操作另外一個域的絕大部分屬性和方法。那么什么叫相同域,什么叫不同的域呢?當兩個域具有相同的協議(如http),相同的端口(如80),相同的host(如www.example.org),那么我們就可以認為它們是相同的域。

比如http://www.example.org/index.html和http://www.example.org/sub/index.html是同域,而http://www.example.org,https://www.example.org,http://www.example.org:8080,http://sub.example.org中的任何兩個都將構成跨域。同源策略還應該對一些特殊情況做處理,比如限制file協議下腳本的訪問權限。本地的HTML文件在瀏覽器中是通過file協議打開的,如果腳本能通過file協議訪問到硬盤上其它任意文件,就會出現安全隱患,目前IE8還有這樣的隱患。

受到同源策略的影響,跨域資源共享就會受到制約。但是隨著人們的實踐和瀏覽器的進步,目前在跨域請求的技巧上,有很多寶貴經驗的沉淀和積累。這里我把跨域資源共享分成兩種,一種是單向的數據請求,還有一種是雙向的消息通信。接下來我將羅列出常見的一些跨域方式,以下跨域實例的源代碼可以從這里獲得。

單向跨域

JSONP(JSONwithPadding)是一個簡單高效的跨域方式,HTML中的script標簽可以加載并執行其他域的javascript,于是我們可以通過script標記來動態加載其他域的資源。

例如我要從域A的頁面pageA加載域B的數據,那么在域B的頁面pageB中我以JavaScript的形式聲明pageA需要的數據,然后在pageA中用script標簽把pageB加載進來,那么pageB中的腳本就會得以執行。JSONP在此基礎上加入了回調函數,pageB加載完之后會執行pageA中定義的函數,所需要的數據會以參數的形式傳遞給該函數。

JSONP易于實現,但是也會存在一些安全隱患,如果第三方的腳本隨意地執行,那么它就可以篡改頁面內容,截獲敏感數據。但是在受信任的雙方傳遞數據,JSONP是非常合適的選擇。

flash有自己的一套安全策略,服務器可以通過crossdomain.xml文件來聲明能被哪些域的SWF文件訪問,SWF也可以通過API來確定自身能被哪些域的SWF加載。當跨域訪問資源時,例如從域www.a.com請求域www.b.com上的數據,我們可以借助flash來發送HTTP請求。

首先,修改域www.b.com上的crossdomain.xml(一般存放在根目錄,如果沒有需要手動創建),把www.a.com加入到白名單。

其次,通過FlashURLLoader發送HTTP請求。

***,通過FlashAPI把響應結果傳遞給JavaScript。FlashURLLoader是一種很普遍的跨域解決方案,不過需要支持iOS的話,這個方案就無能為力了。

window對象的name屬性是一個很特別的屬性,當該window的location變化,然后重新加載,它的name屬性可以依然保持不變。那么我們可以在頁面A中用iframe加載其他域的頁面B,而頁面B中用JavaScript把需要傳遞的數據賦值給window.name,iframe加載完成之后,頁面A修改iframe的地址,將其變成同域的一個地址,然后就可以讀出window.name的值了。這個方式非常適合單向的數據請求,而且協議簡單、安全。不會像JSONP那樣不做限制地執行外部腳本。

在數據提供方沒有提供對JSONP協議或者window.name協議的支持,也沒有對其它域開放訪問權限時,我們可以通過serverproxy的方式來抓取數據。例如當www.a.com域下的頁面需要請求www.b.com下的資源文件asset.txt時,直接發送一個指向www.b.com/asset.txt的Ajax請求肯定是會被瀏覽器阻止。

這時,我們在www.a.com下配一個代理,然后把Ajax請求綁定到這個代理路徑下,例如www.a.com/proxy/,然后這個代理發送HTTP請求訪問www.b.com下的asset.txt,跨域的HTTP請求是在服務器端進行的,客戶端并沒有產生跨域的Ajax請求。這個跨域方式不需要和目標資源簽訂協議,帶有侵略性,另外需要注意的是實踐中應該對這個代理實施一定程度的保護,比如限制他人使用或者使用頻率。

雙向跨域

通過修改document的domain屬性,我們可以在域和子域或者不同的子域之間通信。同域策略認為域和子域隸屬于不同的域,比如www.a.com和sub.a.com是不同的域,這時,我們無法在www.a.com下的頁面中調用sub.a.com中定義的JavaScript方法。但是當我們把它們document的domain屬性都修改為a.com,瀏覽器就會認為它們處于同一個域下,那么我們就可以互相調用對方的method來通信了。

不同的域之間,JavaScript只能做很有限的訪問和操作,其實我們利用這些有限的訪問權限就可以達到跨域通信的目的了。FIM(FragmentIdentitierMessaging)就是在這個大前提下被發明的。父窗口可以對iframe進行URL讀寫,iframe也可以讀寫父窗口的URL,URL有一部分被稱為frag,就是#號及其后面的字符,它一般用于瀏覽器錨點定位,Server端并不關心這部分,應該說HTTP請求過程中不會攜帶frag,所以這部分的修改不會產生HTTP請求,但是會產生瀏覽器歷史記錄。

FIM的原理就是改變URL的frag部分來進行雙向通信。每個window通過改變其他window的location來發送消息,并通過監聽自己的URL的變化來接收消息。這個方式的通信會造成一些不必要的瀏覽器歷史記錄,而且有些瀏覽器不支持onhashchange事件,需要輪詢來獲知URL的改變,***,URL在瀏覽器下有長度限制,這個制約了每次傳送的數據量。

頁面上的雙向通信也可以通過Flash來解決,FlashAPI中有LocalConnection這個類,該類允許兩個SWF之間通過進程通信,這時SWF可以播放在獨立的FlashPlayer或者AIR中,也可以嵌在HTML頁面或者是PDF中。遵循這個通信原則,我們可以在不同域的HTML頁面各自嵌套一個SWF來達到相互傳遞數據的目的了。

SWF通過LocalConnection交換數據是很快的,但是每次的數據量有40kb的大小限制。用這種方式來跨域通信過于復雜,而且需要了2個SWF文件,實用性不強。

window.postMessage是HTML5定義的一個很新的方法,這個方法可以很方便地跨window通信。由于它是一個很新的方法,所以在很舊和比較舊的瀏覽器中都無法使用。

JAVASCRIPT總結

跨域的方法很多,不同的應用場景我們都可以找到一個最合適的解決方案。比如單向的數據請求,我們應該優先選擇JSONP或者window.name,雙向通信我們采取CrossFrame,在未與數據提供方沒有達成通信協議的情況下我們也可以用serverproxy的方式來抓取數據。

希望通過本文的介紹,能夠給你帶來幫助。

【編輯推薦】

  1. 快速排序(Quicksort)的Javascript實現
  2. 用Javascript獲取頁面元素的位置
  3. 論Javascript的類繼承
  4. Javascript中的函數聲明和函數表達式
  5. Javascript閉包(closure) 深入淺出
責任編輯:于鐵 來源: 互聯網
相關推薦

2011-04-08 09:16:12

JavaScript

2021-06-15 07:32:59

Cookie和Sess實現跨域

2021-04-27 15:20:41

人工智能機器學習技術

2019-03-13 14:15:25

CORS跨域資源前端

2011-07-08 09:07:11

JavaScript

2017-03-12 19:51:38

js實用跨域

2020-12-20 18:00:04

跨域請求開發CORS

2011-02-22 17:14:20

2013-11-27 10:23:23

2024-05-20 09:28:44

Spring客戶端瀏覽器

2011-11-07 11:15:31

2017-08-22 15:58:56

2021-03-09 08:50:58

JavaScript前端作用域

2013-07-11 10:08:05

2024-08-28 08:45:22

2018-11-26 14:52:12

Web前端跨域

2023-05-06 15:32:04

2009-02-18 09:30:10

AJAX跨域XML

2019-04-10 10:32:16

CORSNginx反向代理

2016-11-01 21:51:03

phpjavascript
點贊
收藏

51CTO技術棧公眾號

国产在线播放一区二区| av黄在线观看| 欧美视频精品在线观看| 久9久9色综合| www..com日韩| 99久免费精品视频在线观看| 国产精品国产福利国产秒拍 | 风间由美中文字幕在线看视频国产欧美| 欧美丝袜自拍制服另类| 国产色a在线观看| 日韩女优av电影| 久久91视频| 亚洲视频在线观看| 免费观看久久av| 亚洲一区二区在线免费观看| 亚洲精品免费电影| 国产精品视频一区二区三区综合| 丝袜美腿玉足3d专区一区| 欧美色视频日本版| 日本在线电影一区二区三区| 又黄又免费的网站| 欧美人成在线视频| 国产一区二区在线看| 91超碰在线播放| 图片区小说区区亚洲五月| 91激情在线视频| 91综合久久一区二区| 玖玖在线免费视频| 亚洲国产中文字幕在线视频综合| 国产成人黄色网址| 天天免费综合色| 369你懂的电影天堂| 亚洲一区二区av在线| 亚洲区欧洲区| 亚洲在线观看视频| 久久成人精品无人区| 99riav视频| 中文字幕日韩精品有码视频| 成人一道本在线| 日韩理论电影院| 国产l精品国产亚洲区久久| 超碰97人人射妻| 欧美日韩在线第一页| 搞黄视频在线观看| 精品卡一卡二卡三卡四在线| 欧美日韩麻豆| 亚洲国产精品无码av| 欧美一区二区国产| 欧美三级美国一级| 欧洲视频一区二区三区| 91精品国产高清一区二区三区 | 美女国内精品自产拍在线播放| 久久婷婷国产综合精品青草| 欧美**字幕| 天堂在线看视频| 欧美精品一区二区三区久久| 亚洲石原莉奈一区二区在线观看| 国产欧美一区二区三区网站 | 台湾无码一区二区| 国产精品高潮呻吟久久av无限| 亚洲丰满少妇videoshd| 久久永久免费| 人人爱人人干婷婷丁香亚洲| 欧美vide| 资源网第一页久久久| 国产精品第8页| 国产三级一区二区三区| 久久综合五月| 成功精品影院| 免费在线看污片| 一级片在线观看| 久久免费视频3| 国产精品乱人伦| 在线日韩网站| 宅男噜噜噜66国产精品免费| 99re在线视频| aaa免费看大片| 国产视频九色蝌蚪| 成人av电影免费| 精品国产一区二区三区四区在线观看| 亚洲欧美中日韩| 从欧美一区二区三区| 欧美日本不卡| 久久在线播放| 日韩一区二区三区免费播放| 不卡精品视频| 偷拍中文亚洲欧美动漫| segui88久久综合| 日本中文字幕电影在线免费观看| 免费裸体视频网站| 日韩精品无码一区二区三区免费| 欧美色图另类小说| 先锋影音男人资源| 免费看av软件| 日韩一二区视频| 国产精品区在线| 在线免费观看高清视频色| 亚洲人av在线| 日本不卡影院| 视频一区中文字幕精品| 欧美人妖在线观看| 老司机精品在线| 91精品国产调教在线观看| 欧美日韩一卡| 国产精品白丝jk白祙喷水网站 | 97视频资源在线观看| 欧美日韩一区二区视频在线| av在线免费观看国产| 九色丨porny丨| 老司机午夜在线| 国产日韩在线观看视频| 精品一区二区三区在线| 日本在线不卡一区| 中文字幕二三区不卡| 欧美精品18+| 91高清免费在线观看| 成人网欧美在线视频| 日韩免费在线观看av| 久久精品a一级国产免视看成人 | 一区精品视频| 污网站在线播放| 欧美日韩在线精品一区二区三区激情综合| av老司机在线观看| 国产探花在线精品| 国产aⅴ综合色| 欧美人妖巨大在线| 国产精品美女久久久久久免费| 中文精品一区二区三区| 香蕉国产在线| 国产精品**亚洲精品| 日韩亚洲精品在线| 亚洲精品乱码久久久久久久久| 中文字幕国产日韩| 91精品视频观看| 精品一区二区三区视频| 日本三级在线播放完整版| 黄色成人在线网| 外国成人毛片| 国产成人午夜视频| 亚洲国产天堂网精品网站| 99re国产在线播放| 少妇免费视频| 波多野结衣在线观看一区二区三区| 国产日韩av一区| 在线观看亚洲视频| 成人在线视频一区二区三区| 夜色资源站国产www在线视频 | 久久五月天婷婷| 国产三区在线观看| 西西人体一区二区| 日韩欧美激情四射| 人人澡人人澡人人看欧美| siro系绝美精品系列| 给我免费播放日韩视频| 国产亚洲欧美在线| 国产精品久久久av久久久| 天天爽人人爽夜夜爽| 国产中文精品久高清在线不| 欧美国产精品专区| 国产91免费看片| 国产一二三区在线| 久久国产视频网| 中文字幕不卡在线视频极品| 色综合天天综合色综合av| 日韩美女主播视频| 亚洲1卡2卡3卡4卡乱码精品| 亚洲综合不卡| 欧美精品一区二区精品网| 伊人色综合影院| 久久国产精品免费精品3p| 91传媒视频在线播放| 伊人再见免费在线观看高清版 | 蜜桃视频www网站在线观看| 粉嫩aⅴ一区二区三区四区| 久久91亚洲人成电影网站| 毛片视频免费观看| 青青草国产免费一区二区下载| 欧美日韩一区视频| 日日碰狠狠躁久久躁婷婷| 成人h动漫免费观看网站| 欧美日韩免费不卡视频一区二区三区| 翔田千里亚洲一二三区| 亚洲2区在线| 欧美日韩三级一区| 欧美亚洲日本一区二区三区| 亚洲日本va中文字幕| 欧美一级在线免费| 国产又粗又长又大的视频| 日本aⅴ亚洲精品中文乱码| 日本久久久久久久| 亚洲欧美在线成人| 777奇米成人网| 中文字幕亚洲无线码a| 男女网站在线观看| 国产午夜亚洲精品理论片色戒| 亚洲自拍偷拍区| 国产伦乱精品| 久久91亚洲精品中文字幕| 网友自拍亚洲| 国产丝袜一区二区三区免费视频 |