摘要:解決問題即時(shí)通信要解決三方面的問題雙全工通信低延時(shí)支持跨域各種即時(shí)通信技術(shù)輪詢客戶端定時(shí)向服務(wù)器發(fā)送請(qǐng)求,服務(wù)器接到請(qǐng)求后馬上返回響應(yīng)信息并關(guān)閉連接。優(yōu)點(diǎn)實(shí)現(xiàn)真正的即時(shí)通信,而不是偽即時(shí)。
解決問題
即時(shí)通信要解決三方面的問題:
雙全工通信
低延時(shí)
支持跨域
各種即時(shí)通信技術(shù) 輪詢客戶端定時(shí)向服務(wù)器發(fā)送Ajax請(qǐng)求,服務(wù)器接到請(qǐng)求后馬上返回響應(yīng)信息并關(guān)閉連接。
優(yōu)點(diǎn):后端程序編寫比較容易。
缺點(diǎn):請(qǐng)求中有大半是無用,浪費(fèi)帶寬和服務(wù)器資源。
實(shí)例:適于小型應(yīng)用。
客戶端向服務(wù)器發(fā)送Ajax請(qǐng)求,服務(wù)器接到請(qǐng)求后hold住連接,直到有新消息才返回響應(yīng)信息并關(guān)閉連接,客戶端處理完響應(yīng)信息后再向服務(wù)器發(fā)送新的請(qǐng)求。
優(yōu)點(diǎn):在無消息的情況下不會(huì)頻繁的請(qǐng)求。
缺點(diǎn):服務(wù)器hold連接會(huì)消耗資源。
實(shí)例:WebQQ、Hi網(wǎng)頁版、Facebook IM。
在頁面里嵌入一個(gè)隱蔵iframe,將這個(gè)隱蔵iframe的src屬性設(shè)為對(duì)一個(gè)長連接或是采用xhr請(qǐng)求的請(qǐng)求,服務(wù)器端就能源源不斷地往客戶端輸入數(shù)據(jù)。
優(yōu)點(diǎn):消息即時(shí)到達(dá),不發(fā)無用請(qǐng)求。
缺點(diǎn):服務(wù)器維護(hù)一個(gè)長連接會(huì)增加開銷。
實(shí)例:Gmail聊天
技術(shù)細(xì)節(jié):
● XHR 利用onreadystatechange=3去做一些事:當(dāng)它的readyState為3的時(shí)候,獲取它的responseText然后進(jìn)行處理,readyState為3表示數(shù)據(jù)傳送中,整個(gè)通信過程還沒有結(jié)束,所以它還在不斷獲取服務(wù)端發(fā)送過來的數(shù)據(jù),直到readyState為4的時(shí)候才表示數(shù)據(jù)發(fā)送完畢,一次通信過程結(jié)束。
● 利用Iframe做一些事: 低版本的IE不允許在XHR的readyState為3的時(shí)候獲取其responseText屬性,為了達(dá)到在IE上使用這個(gè)技術(shù),又出現(xiàn)了基于iframe的數(shù)據(jù)流通信方式。在瀏覽器中動(dòng)態(tài)載入一個(gè)iframe,讓它的src屬性指向請(qǐng)求的服務(wù)器的URL,實(shí)際上就是向服務(wù)器發(fā)送了一個(gè)http請(qǐng)求,然后在瀏覽器端創(chuàng)建一個(gè)處理數(shù)據(jù)的函數(shù),在服務(wù)端通過iframe與瀏覽器的長連接定時(shí)輸出數(shù)據(jù)給客戶端,但是這個(gè)返回的數(shù)據(jù)并不是一般的數(shù)據(jù),而是一個(gè)類似于腳本執(zhí)行的方式,瀏覽器接收到這個(gè)數(shù)據(jù)就會(huì)將它解析成js代碼并找到頁面上指定的函數(shù)去執(zhí)行,實(shí)際上是服務(wù)端間接使用自己的數(shù)據(jù)間接調(diào)用了客戶端的代碼,達(dá)到實(shí)時(shí)更新客戶端的目的。
● 動(dòng)態(tài)生成一個(gè)htmlfile對(duì)象,這個(gè)對(duì)象ActiveX形式的com組件,它實(shí)際上就是一個(gè)在內(nèi)存中實(shí)現(xiàn)的HTML文檔,通過將生成的iframe添加到這個(gè)內(nèi)存中的HTMLfile中,并利用iframe的數(shù)據(jù)流通信方式達(dá)到上面的效果。同時(shí)由于HTMLfile對(duì)象并不是直接添加到頁面上的,所以并沒有造成瀏覽器顯示正在加載的現(xiàn)象。代碼如下。
在頁面中內(nèi)嵌入一個(gè)使用了Socket類的 Flash 程序JavaScript通過調(diào)用此Flash程序提供的Socket接口與服務(wù)器端的Socket接口進(jìn)行通信,JavaScript在收到服務(wù)器端傳送的信息后控制頁面的顯示。
優(yōu)點(diǎn):實(shí)現(xiàn)真正的即時(shí)通信,而不是偽即時(shí)。
缺點(diǎn):客戶端必須安裝Flash插件;非HTTP協(xié)議,無法自動(dòng)穿越防火墻。
實(shí)例:網(wǎng)絡(luò)互動(dòng)游戲。
為了解決瀏覽器只能夠單向傳輸數(shù)據(jù)到服務(wù)端能夠?qū)崿F(xiàn)客戶端請(qǐng)求服務(wù)端,然后服務(wù)端利用與客戶端建立的這條通信連接push數(shù)據(jù)給客戶端,客戶端接收數(shù)據(jù)并處理的目的。從獨(dú)立的角度看,SSE技術(shù)提供的是從服務(wù)器單向推送數(shù)據(jù)給瀏覽器的功能,但是配合瀏覽器主動(dòng)請(qǐng)求,實(shí)際上就實(shí)現(xiàn)了客戶端和服務(wù)器的雙向通信。它的原理是在客戶端構(gòu)造一個(gè)eventSource對(duì)象,該對(duì)象具有readySate屬性,分別表示如下:
webSocket(HTML5)在HTML5中,為了加強(qiáng)web的功能,提供了websocket技術(shù),它不僅是一種web通信方式,也是一種應(yīng)用層協(xié)議。它提供了瀏覽器和服務(wù)器之間原生的雙全工跨域通信,通過瀏覽器和服務(wù)器之間建立websocket連接(實(shí)際上是TCP連接),在同一時(shí)刻能夠?qū)崿F(xiàn)客戶端到服務(wù)器和服務(wù)器到客戶端的數(shù)據(jù)發(fā)送。
首先是客戶端new 一個(gè)websocket對(duì)象,該對(duì)象會(huì)發(fā)送一個(gè)http請(qǐng)求到服務(wù)端,服務(wù)端發(fā)現(xiàn)這是個(gè)webscoket請(qǐng)求,會(huì)同意協(xié)議轉(zhuǎn)換,發(fā)送回客戶端一個(gè)101狀態(tài)碼的response,以上過程稱之為一次握手,經(jīng)過這次握手之后,客戶端就和服務(wù)端建立了一條TCP連接,在該連接上,服務(wù)端和客戶端就可以進(jìn)行雙向通信了。這時(shí)的雙向通信在應(yīng)用層走的就是ws或者wss協(xié)議了,和http就沒有關(guān)系了。所謂的ws協(xié)議,就是要求客戶端和服務(wù)端遵循某種格式發(fā)送數(shù)據(jù)報(bào)文(幀),然后對(duì)方才能夠理解。
在HTTP/1.0中,默認(rèn)使用的是短連接。也就是說,瀏覽器和服務(wù)器每進(jìn)行一次HTTP操作,就建立一次連接,但任務(wù)結(jié)束就中斷連接。如果客戶端瀏覽器訪問的某個(gè)HTML或其他類型的 Web頁中包含有其他的Web資源,如JavaScript文件、圖像文件、CSS文件等;當(dāng)瀏覽器每遇到這樣一個(gè)Web資源,就會(huì)建立一個(gè)HTTP會(huì)話。
但從 HTTP/1.1起,默認(rèn)使用長連接,用以保持連接特性。使用長連接的HTTP協(xié)議,會(huì)在響應(yīng)頭有加入這行代碼:
Connection:keep-alive
在使用長連接的情況下,當(dāng)一個(gè)網(wǎng)頁打開完成后,客戶端和服務(wù)器之間用于傳輸HTTP數(shù)據(jù)的 TCP連接不會(huì)關(guān)閉,如果客戶端再次訪問這個(gè)服務(wù)器上的網(wǎng)頁,會(huì)繼續(xù)使用這一條已經(jīng)建立的連接。Keep-Alive不會(huì)永久保持連接,它有一個(gè)保持時(shí)間,可以在不同的服務(wù)器軟件(如Apache)中設(shè)定這個(gè)時(shí)間。實(shí)現(xiàn)長連接要客戶端和服務(wù)端都支持長連接。
HTTP協(xié)議的長連接和短連接,實(shí)質(zhì)上是TCP協(xié)議的長連接和短連接。
Socket.IO是一個(gè)完全由JavaScript實(shí)現(xiàn)、基于Node.js、支持WebSocket的協(xié)議用于實(shí)時(shí)通信、跨平臺(tái)的開源框架,它包括了客戶端的JavaScript和服務(wù)器端的Node.js。Socket.IO除了支持WebSocket通訊協(xié)議外,還支持許多種輪詢(Polling)機(jī)制以及其它實(shí)時(shí)通信方式,并封裝成了通用的接口,并且在服務(wù)端實(shí)現(xiàn)了這些實(shí)時(shí)機(jī)制的相應(yīng)代碼。Socket.IO實(shí)現(xiàn)的Polling通信機(jī)制包括Adobe Flash Socket、AJAX長輪詢、AJAX multipart streaming、持久Iframe、JSONP輪詢等。
本文為網(wǎng)上資料匯總+自己的理解
Socket.IO介紹:支持WebSocket、用于WEB端的即時(shí)通訊框架
史上最全Web端即時(shí)通訊技術(shù)原理詳解
知乎回答
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/89218.html
摘要:本畢業(yè)設(shè)計(jì)旨在為各個(gè)公司開發(fā)一款即時(shí)通訊軟件為公司內(nèi)部員工的工作和交流提供幫助。三主要設(shè)計(jì)內(nèi)容本畢業(yè)設(shè)計(jì)主要實(shí)現(xiàn)一個(gè)即時(shí)通訊軟件,總共分客戶端與服務(wù)器端。處理流程類繼承了類,實(shí)現(xiàn)多線程,并通過傳輸線程的數(shù)量進(jìn)行文件傳輸。 ...
閱讀 1744·2023-04-25 23:43
閱讀 915·2021-11-24 09:39
閱讀 719·2021-11-22 15:25
閱讀 1720·2021-11-22 12:08
閱讀 1090·2021-11-18 10:07
閱讀 2079·2021-09-23 11:22
閱讀 3346·2021-09-22 15:23
閱讀 2495·2021-09-13 10:32