python2.0_s12_day21_web聊天室一

本節內容:css

項目實戰:開發一個WEB聊天室html

功能需求:html5

  1. 用戶能夠與好友一對一聊天
  2. 能夠搜索、添加某人爲好友
  3. 用戶能夠搜索和添加羣
  4. 每一個羣有管理員能夠審批用戶的加羣請求,羣管理員能夠用多個,羣管理員能夠刪除、添加、禁言羣友
  5. 能夠與聊天室裏的人進行臨時會話(與qq羣同樣)
  6. 能夠在羣中發圖片
  7. 能夠與好友一對一發文件

知識必備:jquery

  1. django 
  2. html\css\js
  3. bootstrap
  4. jquery, ajax

 

 

前景介紹

首先咱們知道http是無狀態、請求/響應模式的通訊模式,就是用戶每次經過瀏覽器點擊一下頁面,都須要從新與WEB服務器創建一次鏈接,且發送本身的session id給服務器端以使服務器端驗證此用戶的身份。 客戶端若想從web服務器上獲取數據,必須主動發起一個請求,而後接收服務器端的返回,服務器端不會主動往客戶端推送消息。 web

基於傳統的WEB服務器只會被動響應客戶端請求的這個認知,若是咱們想實現WEB實時聊天的需求,基本上只有如下幾種方式:ajax

輪詢(polling)

輪詢 (Polling) 涉及了從客戶端向服務器端發出請求以獲取一些數據,這顯然就是一個純粹的 Ajax HTTP 請求。爲了儘快地得到服務器端事件,輪詢的間隔(兩次請求相隔的時間)必須儘量地小。但有這樣的一個缺點存在:若是間隔減少的話,客戶端瀏覽器就會發出更多的請求,這些請求中的許多都不會返回任何有用的數據,而這將會白白地浪費掉帶寬和處理資源。django

Comet

使用了輪詢的Ajax 很是受限:其不具伸縮性,不提供低延遲通訊(只要事件一到達服務器端,它們就以儘量快的速度到達瀏覽器端)。 Comet 是一個 Web 應用模型,在該模型中,請求被髮送到服務器端並保持一個很長的存活期,直到超時或是有服務器端事件發生。在該請求完成後,另外一個長生存期的 Ajax 請求就被送去等待另外一個服務器端事件。bootstrap

Comet 的一大優勢是,每一個客戶端始終都有一個向服務器端打開的通訊鏈路。服務器端能夠經過在事件到來時當即提交(完成)響應來把事件推給客戶端,或者它甚至能夠累積再連續發送。由於請求長時間保持打開的狀態,故服務器端須要特別的功能來處理全部的這些長生存期請求。後端

 

Comet的實現主要有兩種方式:瀏覽器

基於Ajax的長輪詢(long-polling)方式

瀏覽器發出XMLHttpRequest 請求,服務器端接收到請求後,會阻塞請求直到有數據或者超時才返回,瀏覽器JS在處理請求返回信息(超時或有效數據)後再次發出請求,從新創建鏈接。在此期間服務器端可能已經有新的數據到達,服務器會選擇把數據保存,直到從新創建鏈接,瀏覽器會把全部數據一次性取回。

Forever Iframe(永存的 Iframe)

此技術涉及了一個置於頁面中的隱藏 Iframe 標籤,該標籤的 src 屬性指向返回服務器端事件的 servlet 路徑。每次在事件到達時,servlet 寫入並刷新一個新的 script 標籤,該標籤內部帶有 JavaScript 代碼,iframe 的內容被附加上這一 script 標籤,標籤中的內容就會獲得執行。

 

 

WebSocket 

若是說Ajax的出現是互聯網發展的必然,那麼Comet技術的出現則更多透露出一種無奈,僅僅做爲一種hack技術,由於沒有更好的解決方案。Comet解決的問題應該由誰來解決纔是合理的呢?瀏覽器,html標準,仍是http標準?主角應該是誰呢?本質上講,這涉及到數據傳輸方式,http協議應首當其衝,是時候改變一下這個懶惰的協議的請求/響應模式了。

W3C給出了答案,在新一代html標準html5中提供了一種瀏覽器和服務器間進行全雙工通信的網絡技術Websocket。從Websocket草案得知,Websocket是一個全新的、獨立的協議,基於TCP協議,與http協議兼容、卻不會融入http協議,僅僅做爲html5的一部分。因而乎腳本又被賦予了另外一種能力:發起websocket請求。這種方式咱們應該很熟悉,由於Ajax就是這麼作的,所不一樣的是,Ajax發起的是http請求而已。 

與http協議不一樣的請求/響應模式不一樣,Websocket在創建鏈接以前有一個Handshake(Opening Handshake)過程,在關閉鏈接前也有一個Handshake(Closing Handshake)過程,創建鏈接以後,雙方便可雙向通訊。

 



以上幾種實現方式的優缺點

輪詢:客戶端定時向服務器發送Ajax請求,服務器接到請求後立刻返回響應信息並關閉鏈接。 
優勢:後端程序編寫比較容易。 
缺點:請求中有大半是無用,浪費帶寬和服務器資源。 
實例:適於小型應用。


長輪詢:客戶端向服務器發送Ajax請求,服務器接到請求後hold住鏈接,直到有新消息才返回響應信息並關閉鏈接,客戶端處理完響應信息後再向服務器發送新的請求。 
優勢:在無消息的狀況下不會頻繁的請求,耗費資源小。 
缺點:服務器hold鏈接會消耗資源,返回數據順序無保證,難於管理維護。 
實例:WebQQ、Hi網頁版、Facebook IM。

 

長鏈接:在頁面裏嵌入一個隱蔵iframe,將這個隱蔵iframe的src屬性設爲對一個長鏈接的請求或是採用xhr請求,服務器端就能源源不斷地往客戶端輸入數據。 
優勢:消息即時到達,不發無用請求;管理起來也相對方便。 
缺點:服務器維護一個長鏈接會增長開銷。 
實例:Gmail聊天


Flash Socket:在頁面中內嵌入一個使用了Socket類的 Flash 程序JavaScript經過調用此Flash程序提供的Socket接口與服務器端的Socket接口進行通訊,JavaScript在收到服務器端傳送的信息後控制頁面的顯示。 優勢:實現真正的即時通訊,而不是僞即時。 缺點:客戶端必須安裝Flash插件;非HTTP協議,沒法自動穿越防火牆。 實例:網絡互動遊戲。

相關文章
相關標籤/搜索