中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

詳解HTML5中的Communication API基本使用方法
來源:易賢網 閱讀:1596 次 日期:2016-07-09 09:52:37
溫馨提示:易賢網小編為您整理了“詳解HTML5中的Communication API基本使用方法”,方便廣大網友查閱!

這篇文章主要介紹了HTML5中的Communication API基本使用方法,文中涉及了用于構建實時和跨域通信的兩個重要模塊:跨文檔消息通訊和XMLHttpRequest Level 2,需要的朋友可以參考下

1.跨文檔消息通信

跨文檔消息通信可以確保iframe、標簽頁、窗口間安全地進行跨源通信。它把postMessage API定義為發送消息的標準方式。利用postMessage發送消息非常簡單,代碼如下所示:

chatFrame.contextWindow.postMessage('Hello,world','http://www.example.com');

接收消息時僅需在頁面種增加一個事件處理函數。當某個消息到達時,通過檢查消息的來源來決定是否對這條消息進行處理。

消息事件是一個擁有data(數據)和origin(源)屬性的DOM事件。data屬性是發送方傳遞的實際消息,而origin屬性是發送來源。

postMessage API不僅可以勝任同源文檔間的通信,而且在瀏覽器不允許非同源通信的情況下,postMessage API也很有用。鑒于它的一致性和易用性,在同源文檔間通信時也推薦使用postMessage。在JavaScript環境的通信中始終應使用postMessage API,例如使用HTML5 Web Worker通信時。

1.1 理解源安全

HTML5榮光引入源(origin)的概念對域安全進行了闡明和改進。源是在網絡上用來建立信任關系的地址的子集。源由規則(scheme)、主機(host)、端口(post)組成。

源的概念中不考慮路徑。

HTML5定義了源的序列化。源在API和協議中以字符串的形式出現。

postMessage的安全規則確保了消息不會被傳遞到非預期的源頁面中。當發送消息時,由發送方制定接收方的源。如果發送方用來調用postMessage的窗口不具有特定的源(例如用戶跳轉到了其他站點),瀏覽器就不會傳送消息。

類似地,接受消息的時候,發送方的源也被作為消息的一部分。為避免偽造,消息源由瀏覽器提供。接收方可以決定處理哪些消息,以及忽略哪些消息。我們可以保留一份白名單,告訴瀏覽器僅僅處理可信源的消息。

最好永遠不要對來自第三方的字符串求值。再者,要避免使用eval方法處理應用內部字符串。可以通過window.JSON或者json,.org解析器使用JSON。

1.2 跨文檔消息通信的瀏覽器支持情況

常用的做法是檢測XMLHttpRequest對象中是否存在withCredentials屬性:

JavaScript Code

var xhr = new XMLHttpRequest(); if (typeof xhr.withCredentials === undefined) { //不支持跨源的XMLHttpRequest } else { //支持跨源的XMLHttpRequest }  

1.3 使用postMessage API

提示 HTML5定義的MessageEvent接口也是HTML5 WebSockets和HTML5 WebWorkers的一部分。HTML5的通信功能用用于接受消息的API與MessageEvent接口是一致的。其他通信類API,如EventSource API和Web Workers,也都是使用MessageEvent接口來傳遞消息。

1.4 使用postMessage API創建應用

發送消息

通過調用目標頁面window對象中的postMessage()函數可發送消息,代碼如下:

JavaScript Code

window.postMessage("Hello, world", "porta");  

第一個參數包括要發送的數據,第二個參數是消息傳送的目的地。要發送消息給iframe,可以再相應iframe的contentWindow中調用postMessage,代碼如下:

JavaScript Code

document.getElementsByTagName("iframe")[0].contentWindow.postMessage("Hello, world", "cha");  

監聽消息事件

接收消息時僅需在頁面中增加一個事件處理函數。當某個消息到達時,通過檢查消息的來源來決定是否對這條消息進行處理。

JavaScript Code

window.postMessage("Hello, world", "porta");  

消息事件是一個擁有data(數據)和origin(源)屬性的DOM事件。data屬性是發送方傳遞的實際消息,而origin屬性是發送來源。

源由規則(scheme)、主機(host)、端口(port)組成。

例如:由于規則不同(如https與http),所以頁面與頁面的源是不同的。

源的概念中不考慮路徑。如:與只是路徑不同,他們是相同的源。

源在API和協議中以字符串的形式出現。

JavaScript Code

var originWhiteList = ["porta", "game", ""]; function checkWhiteList(origin) { for (var i=0; i<originWhiteList.length; i++) { if (origin === originWhiteList[i]) { return true; } } return false; } function messageHandler(e) { if (checkWhiteList(e.origin)) { processMessage(e.data); } else { //忽略來自未知源的消息 } }  

postMessage API可以適用于同源和非同源通信,鑒于它的一致性,在同源文檔間通信時也推薦適用postMessage。

2 XMLHttpRequest Level2

作為XMLHttpRequest的改進版,XMLHttpRequest Level2在功能上有了很大的改進。主要集中在兩個方面:

(1)跨源XMLHttpRequests;

(2)進度事件(Progress events)

2.1 跨源XMLHttpRequst

XMLHttpRequestLevel2通過CORS(Cross Origin Resource Sharing,跨源資源共享)實現了跨源XMLHttpRequests。

跨源HTTP請求包括一個Origin頭部,拓為服務器提供HTTP請求的源信息。頭部由瀏覽器保護,不能被應用程序代碼修改。從本質上講,它與跨文檔消息通信中消息事件的origin屬性作用相同。

CORS規范要求,對一些敏感行為——如申請證書的請求或除了GET和POST以外的OPTIONS預檢(preflight)請求,必須由瀏覽器發送給服務器,以確定這種行為能否被支持和允許,這意味著成功通信的背后或許需要由具備CORS出了能力的服務器來支持。

2.2 進度事件

新版XMLHttpRequest中最重要的API改進之一是增加了對進度的響應。

XMLHttpRequest Level2用了一個有意義的名字Progress進度來命名進度事件。

3 進階功能

3.1 結構化的數據

早期版本的postMessage僅支持字符串。后來的版本支持JavaScript對象、canvas imageData和文件等其他數據類型。由于不同瀏覽器對規范支持的差異,對不同的對象類型的支持情況也不同。

3.2 Framebusting

Framebusting技術可以用來保證某些內容不被加載到jframe中。應用程序首先檢測其所在的窗口是否為最外層的窗口(window.top),若不是則跳脫包含它的框架,代碼如下所示:

JavaScript Code

if(window!=window.top)   

{   

window.top.location=location;   

}  

3.3二進制數據

支持新的二進制API(如Typed Array)的瀏覽器可以用XMLHttpRequest來發送二進制數據。Level 2規范支持調用send()方法發送Blob和ArrayBuffer對象

XML/HTML Code

var a = new Uint8Array([8,6,7,5,3,0,9]); var xhr = new XMLHttpRequest(); xhr.open("POST", "/data/", true); console.log(a); xhr.send(a.buffer);  

XMLHttpRequest Level 2也會公開二進制響應數據。將responseType屬性值設置為text、document、arraybuffer或blob來控制 有response屬性返回的對象類型。如果想要查看HTTP響應體包含的原始字節,需要將responseTyper屬性值設為arraybuffer或blob。

更多信息請查看網頁制作
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美电影在哪看比较好| 久久久久久夜精品精品免费| 国产一区日韩二区欧美三区| 亚洲日穴在线视频| 日韩精品一区在线观看| 色综合网色综合| 精品一区二区三区香蕉蜜桃| 亚洲一区二区三区四区在线观看 | 国产精品成人在线观看| 欧美一区日韩一区| 91黄色激情网站| 成人av在线看| 韩国成人精品a∨在线观看| 亚洲自拍偷拍av| 国产精品美女久久久久久| 精品国产一区a| 亚洲第一二三四区| 日韩午夜在线观看视频| 色天天综合久久久久综合片| 国产精品99久| 精品一区二区三区不卡| 91官网在线观看| 成人午夜视频福利| 国产精品一品视频| 国产揄拍国内精品对白| 麻豆国产欧美日韩综合精品二区| 午夜婷婷国产麻豆精品| 一区二区三区在线免费播放| 国产精品国产三级国产aⅴ无密码| www成人在线观看| 日韩欧美视频在线| 欧美一区二区三区系列电影| 欧美日韩久久一区二区| 欧美午夜精品一区二区三区| 色94色欧美sute亚洲线路二| 色呦呦一区二区三区| 色呦呦网站一区| 欧美探花视频资源| 欧美日韩1234| 91精品国产色综合久久不卡蜜臀 | 亚洲精品在线三区| 欧美mv日韩mv| 久久免费美女视频| 欧美经典一区二区三区| 久久精品日产第一区二区三区高清版| 2021国产精品久久精品| www国产精品av| 久久久久久99久久久精品网站| 精品少妇一区二区三区视频免付费 | 在线播放日韩导航| 欧美欧美午夜aⅴ在线观看| 9191久久久久久久久久久| 欧美三级韩国三级日本三斤| 欧美日韩精品电影| 91精品国产色综合久久久蜜香臀| 日韩女优av电影| 久久综合五月天婷婷伊人| 国产午夜精品一区二区三区嫩草| 国产欧美一区二区精品秋霞影院| 中文字幕不卡在线| 1000精品久久久久久久久| 亚洲另类在线一区| 午夜精品福利在线| 精品一区二区久久久| 成人手机在线视频| 日本二三区不卡| 8v天堂国产在线一区二区| 久久综合九色综合97婷婷女人| 国产日韩av一区二区| 亚洲欧美日韩在线不卡| 婷婷中文字幕一区三区| 国产一区啦啦啦在线观看| 91日韩一区二区三区| 欧美精品123区| 中文字幕第一区二区| 亚洲成人黄色影院| 国产老肥熟一区二区三区| 色香蕉成人二区免费| 欧美一区午夜视频在线观看| 中文一区二区完整视频在线观看| 亚洲一区二区三区四区在线| 国产综合色精品一区二区三区| 97精品久久久午夜一区二区三区| 制服丝袜日韩国产| 国产精品国产三级国产| 日韩av二区在线播放| 99久久久免费精品国产一区二区| 欧美日本乱大交xxxxx| 久久精品亚洲一区二区三区浴池| 亚洲精品少妇30p| 国产乱码一区二区三区| 欧美三级日本三级少妇99| 亚洲国产精品成人综合| 青青国产91久久久久久| 色综合欧美在线| 久久久天堂av| 日韩高清电影一区| 色av综合在线| 欧美韩国日本一区| 精品在线亚洲视频| 欧美日韩在线精品一区二区三区激情| 久久久久久毛片| 日本伊人色综合网| 色呦呦一区二区三区| 欧美激情一区二区三区不卡| 久久精品999| 欧美日韩亚州综合| 亚洲日本在线视频观看| 国产精品资源在线| 日韩久久久久久| 日韩精品电影在线观看| 中文av一区二区| 国产自产2019最新不卡| 6080国产精品一区二区| 亚洲国产精品久久不卡毛片| 波多野洁衣一区| 国产欧美精品一区二区色综合 | 国产成人h网站| 日韩欧美中文字幕精品| 午夜精品在线看| 精品视频在线视频| 亚洲精品国产视频| 91色九色蝌蚪| 中文字幕日韩一区| aaa欧美日韩| 国产精品三级av| 国产成人av电影在线| 久久久久久久综合色一本| 国产一区二区三区最好精华液| 日韩免费在线观看| 男女男精品视频网| 欧美一级日韩不卡播放免费| 免费高清在线视频一区·| 欧美日本一区二区| 日韩成人精品在线| 日韩欧美激情一区| 精品综合免费视频观看| 久久久久一区二区三区四区| 九九九久久久精品| 久久久一区二区| 成人综合婷婷国产精品久久 | 丁香婷婷深情五月亚洲| 国产欧美视频在线观看| 成人精品免费网站| 国产精品久久久久久亚洲伦| av中文字幕亚洲| 亚洲一区在线观看视频| 欧美美女一区二区| 免费观看成人av| 国产婷婷色一区二区三区在线| 成人动漫精品一区二区| 亚洲视频狠狠干| 欧美日韩中文字幕精品| 日韩精彩视频在线观看| 精品美女一区二区三区| 国产91在线观看丝袜| 亚洲天堂久久久久久久| 国产精品免费视频网站| 一本久道久久综合中文字幕 | 极品美女销魂一区二区三区免费| 久久久国产综合精品女国产盗摄| 成人一区二区视频| 伊人开心综合网| 欧美一区三区四区| 国产精品一区二区91| 亚洲精品国产成人久久av盗摄| 欧美日韩久久一区| 国产一区二区三区四区五区入口| 国产精品青草综合久久久久99| 99久久精品国产网站| 亚洲大型综合色站| 国产亚洲一二三区| 在线看国产一区二区| 免费一级欧美片在线观看| 国产欧美日韩卡一| 欧美日韩久久一区| 懂色av噜噜一区二区三区av| 亚洲一区二区在线免费观看视频| 日韩一区二区三| 国产suv精品一区二区6| 亚洲成a人片在线不卡一二三区| 久久久久亚洲综合| 欧美日韩国产高清一区二区三区 | 欧美精品aⅴ在线视频| 成人免费视频caoporn| 丝袜美腿亚洲色图| 国产精品久久久久久久久晋中 | 色综合一区二区| 狠狠色丁香婷婷综合| 亚洲最大的成人av| 久久久久久黄色| 欧美精品色综合| 99久久国产免费看| 国产一区视频在线看| 日日摸夜夜添夜夜添亚洲女人| 国产欧美日韩三区| 欧美大度的电影原声| 日本韩国欧美一区二区三区| 国产91精品入口| 久久99久久99|