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