PHP聊天室技術

php(做為現在的主流開發語言)聊天室技術
黃國輝

1.前言
  上網聊天是時下最流行的交友方式。各大網站推出的聊天室都各具特色。
  聊天室主要分為WebChat、BBSChat兩種。BBSChat是基於Telnet的Tcp協議,是BBS的附設功能,需要客戶端Telnet程序。WebChat則采用瀏覽器方式,實際上是一個多人共同使用的cgi(現在已經不多人在用瞭)程序。其基本原理是把每個用戶的發言通過瀏覽器傳給系統,再由系統收集處理後分發給特定用戶。
  WebChat一般采用Server Push或Client Pull技術。兩種技術的區別在於使用不同的方式將數據分發給用戶,Server Push是由服務器將數據以多重MIME編碼,推給(push)使用者端,目前較少網站使用這種方式。Client Pull則是用戶從服務器拉(pull)所要的數據。
  最常用的Client Pull就是利用Html語言的Meta標簽http-equiv=”Refresh” 的屬性,每隔一段時間就檢查服務器上是否有新的數據。例如 ,每隔5秒鐘就會刷新一次頁面。這種方法簡單有效,缺點是刷新時會產生閃爍的現象;而且為瞭保持效率,每次刷新都會把舊的聊天內容清除,用戶想查看或保留對話內容都很不方便。為此,采用JavaApplet作為聊天室的前端,利用刷新把從服務器Pull的數據通過JavaApplet來顯示也是一種解決方案。還有就是本文要介紹的使聊天程序保持連線的方案。方法一,把聊天程序設置為無限大,就能使瀏覽器不停地保持下載的連線狀態;方法二,聊天程序中存在著無限循環,因為可以方便地設置更高級的功能,所以在此選擇采用。
  Web服務器采用FreeBSD+apache(Unix平臺最流行的WEB服務器平臺),原因是兩者的組合具有最強的性能,而且花費為零。還需要考慮的是用什麼方式來存放數據呢。用文件相對而言容易實現,但是多人使用,頻繁地對同一文件進行IO操作,難免會影響效率,況且FreeBSD的IO性能不佳。可以考慮使用RamDisk,將文件整個放進內存,以提高速度。或者在內存中劃分出一塊高速空間用以數據存放。筆者使用的是數據庫方式:MySQL(和PHP搭配之最佳組合)。因為該數據庫就是為大批量用戶同時使用而設計,利用它可以省去設計高速空間操作的復雜編寫,速度也可得到保證。如將整個數據庫放進內存,效果更好。
  程序用php(做為現在的主流開發語言)+Html+JavaScript編寫。聊天室主要是對Html的Form中的各種元素進行操作。JavaScript是基於對象的語言,對Html中的各種元素皆當作對象看待,所以每個元素的方法和屬性都很豐富,操作比較方便。而php(做為現在的主流開發語言)隻有在Form經過Post後,將Form中的元素轉成對應的變量,才能處理用戶輸入的數據。從交互性來說比較差,這也是使用JavaScript的原因。采用php(做為現在的主流開發語言)的原因是因為比起其它cgi(現在已經不多人在用瞭)語言,其速度和安全性都較佳,開發也比較容易。
2. 不斷刷新的聊天室
  一個標準的聊天室頁面由三個Frame組成,分別是顯示在線用戶的Online、用戶發言及功能設置的Say和顯示聊天內容的List。用戶在Say Frame中敲入發言內容後按發送,數據經過處理後保存在MySQL(和PHP搭配之最佳組合)數據庫,同時被保存的還包括發言人、聊天對象及發言的時間。用戶一進入聊天室,List Frame從MySQL(和PHP搭配之最佳組合)數據庫中把發言時間大於用戶進入時間的發言提出顯示出來。而後續顯示新的發言內容的關鍵,在於顯示聊天內容的那段程序是無限循環的。
  List Frame程序概要:
    $db=MySQL(和PHP搭配之最佳組合)_pconnect(localhost,root);    #MySQL(和PHP搭配之最佳組合)數據庫連接
    MySQL(和PHP搭配之最佳組合)_select_db(chat,$db);
    顯示歡迎進入聊天室
    設置$init為數據庫中發言時間比
      進入時間大的第一個數據的ID號   #是數據提取的標志位
    while (1==1) {             #無限循環開始

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *