當(dāng)前位置:首頁 > 物聯(lián)網(wǎng) > 《物聯(lián)網(wǎng)技術(shù)》雜志
[導(dǎo)讀]摘 要:使用PHP服務(wù)器腳本語言,采用Apache服務(wù)器軟件搭建B/S結(jié)構(gòu),將單條聊天內(nèi)容以結(jié)構(gòu)化數(shù)據(jù)庫表對應(yīng)的單條記錄形式存儲于MySQL數(shù)據(jù)庫,再通過Ajax技術(shù)使客戶端與服務(wù)器之間異步發(fā)送和接收信息,從而實現(xiàn)無刷新信息交互。該系統(tǒng)的即時聊天系統(tǒng)界面簡潔,功能專一,可使用戶之間的通訊與信息交流更加便捷。

引 言

互聯(lián)網(wǎng)技術(shù)飛速發(fā)展,Instant Messaging(即時通訊)的出現(xiàn),通過互聯(lián)網(wǎng)技術(shù),革新了當(dāng)代人信息交流的方式,給人們生活帶來諸多便利。當(dāng)前,在“互聯(lián)網(wǎng) +”的國家發(fā)展戰(zhàn)略下, 許多傳統(tǒng)服務(wù)行業(yè)都亟待與互聯(lián)網(wǎng)融合,服務(wù)必然需要一個互聯(lián)網(wǎng)溝通平臺,網(wǎng)頁即時聊天系統(tǒng)便應(yīng)運而生,該系統(tǒng)界面簡潔,功能專一,不需要下載軟件即可實現(xiàn)信息交流,讓信息交流更加便捷。

1 系統(tǒng)設(shè)計

1.1 系統(tǒng)整體架構(gòu)設(shè)計

系統(tǒng)采用B/S 模式開發(fā),具有三層結(jié)構(gòu),具體如圖 1 所示。其中,表現(xiàn)層主要是提供交互的界面,由HTML 完成,業(yè)務(wù)邏輯和數(shù)據(jù)訪問層通過PHP 和MySQL 組合開發(fā),它們是當(dāng)今較為流行的開源技術(shù),便于使用,運行速度快,功能強大, 并且免費,非常適合Web 開發(fā) [1-3] ;業(yè)務(wù)邏輯層則通過 PHP 寫出收發(fā)信息和添刪處理邏輯 ;數(shù)據(jù)庫訪問層通過表的結(jié)構(gòu), 寫出相應(yīng) PHP 服務(wù)類,然后通過PHP 的MySQL 接口來實現(xiàn)數(shù)據(jù)的增刪改查。

基于PHP的網(wǎng)頁即時聊天系統(tǒng)的設(shè)計與實現(xiàn)


1.2 系統(tǒng)數(shù)據(jù)庫設(shè)計 

系統(tǒng)具有發(fā)送信息,添加刪除好友功能,相應(yīng)的有 3 張表, 其中表 1為用戶表,表 2 為信息表,好友關(guān)系表的具體字段設(shè) 置見表 3 所列。 

2 系統(tǒng)核心功能實現(xiàn) 

2.1 驗證功能 

系統(tǒng)界面是通過 HTML 完成,當(dāng)用戶寫入用戶名和密碼 時,通過 get 方式向服務(wù)器發(fā)送請求,服務(wù)器驗證頁面接收到 用戶名和密碼,通過連接數(shù)據(jù)庫,將接收到的用戶名和密碼與 數(shù)據(jù)庫中用戶表的記錄進行逐行比對,如果與某一行完全匹 配,則跳轉(zhuǎn)到聊天界面,否則跳轉(zhuǎn)到注冊界面。圖 2 所示是 其驗證功能流程圖。如果是第一次登陸,生成 session,在服 務(wù)器保存用戶信息。

基于PHP的網(wǎng)頁即時聊天系統(tǒng)的設(shè)計與實現(xiàn)



2.2 發(fā)送信息功能

當(dāng)用戶點擊發(fā)送信息按鈕時,瀏覽器向服務(wù)器發(fā)送 Ajax 請求,服務(wù)器中的處理收發(fā)信息頁面接收來自 Ajax 的請求信 息,其中包括 session 里面的用戶信息,接收人信息,以及發(fā) 送的內(nèi)容,并將這些信息存入信息表中,其中 time 字段用 now ()函數(shù)來代替,is_get 字段不作為字段寫入,默認(rèn)為 0。圖 3所示是其發(fā)送信息功能流程圖。

基于PHP的網(wǎng)頁即時聊天系統(tǒng)的設(shè)計與實現(xiàn)

2.3 接收信息功能 當(dāng)客戶端處于用戶登錄狀態(tài),并且處于聊天界面時,瀏 覽器定時向服務(wù)器發(fā)送獲取信息的請求,通過 js 的 window. setInterval()方法設(shè)定時間,本次設(shè)定為 5 000,即為 5 秒, 此時瀏覽器會間隔 5 秒向服務(wù)器發(fā)送獲取信息的請求,當(dāng)服務(wù) 器接收到瀏覽器的請求后,開始連接數(shù)據(jù)庫,并通過用戶信息, 在數(shù)據(jù)庫的信息表中查找接收人是當(dāng)前用戶的記錄,同時 is_ get 字段的值必須為 0,每取出一條,將該記錄中的 is_get 的 值置 1,在讀取之后,通過 AIAX 回調(diào)函數(shù),使用 DOM 將信 息更新到聊天界面 [4],其中每條信息都是拼接返回,避免覆 蓋上一條信息。 

接收信息功能流程圖如圖 4 所示。

基于PHP的網(wǎng)頁即時聊天系統(tǒng)的設(shè)計與實現(xiàn)


2.4 Ajax Ajax

 是一種用于給用戶更好體驗,交互性更強的 Web 應(yīng) 用程序技術(shù),Ajax 的本質(zhì)是異步的 Javascript 代碼配合 XML 用于 Web 交互,使用 Ajax 使客戶端接收信息,獨立于網(wǎng)頁, 不需要刷新整個網(wǎng)頁就可以得到來自服務(wù)器的交互信息 [5-8]。 它不是新技術(shù),但是能夠給 Web 體驗錦上添花 [9]。即時聊天 系統(tǒng)需要刷新頁面才可以收到信息,這對于用戶是不可接受的, 并且極大地降低了用戶體驗,運用 Ajax 是此系統(tǒng)的核心解決 方案。

如圖 5 所示,在聊天窗口點擊發(fā)送信息按鈕時,瀏覽器 將請求轉(zhuǎn)移到 Ajax 引擎,由 Ajax 引擎發(fā)送請求,即實例化后 的 XMLHttpRequest 對象 [10],服務(wù)器信息處理頁面收到 Ajax 引擎的請求到 MySQL 數(shù)據(jù)庫信息表中取出對應(yīng)信息并轉(zhuǎn)化為 XML 形式,返回給 Ajax 引擎,通過 DOM 將返回到 Ajax 引 擎的信息更新到瀏覽器的聊天窗口,此過程中,瀏覽器沒有執(zhí) 行刷新。

基于PHP的網(wǎng)頁即時聊天系統(tǒng)的設(shè)計與實現(xiàn)


3 結(jié) 語

此聊天系統(tǒng)使用 WAMP 開發(fā)環(huán)境,基于 B/S 三層結(jié)構(gòu) 開發(fā)完成。三層結(jié)構(gòu)很好地將業(yè)務(wù)邏輯和界面分開,便于后 期維護和拓展。收發(fā)信息通過 Ajax 引擎完成,使聊天界面無 刷新更新信息。服務(wù)器軟件和數(shù)據(jù)庫選用 Apache 和 MySQL, 加上 PHP 服務(wù)器腳本程序,代碼簡潔。實踐證明,系統(tǒng)整體 運行良好,無漏接漏發(fā)信息。當(dāng)前傳統(tǒng)服務(wù)行業(yè)發(fā)展的大趨 勢是與互聯(lián)網(wǎng)融合,網(wǎng)頁即時聊天系統(tǒng),輕量級聊天,功能 專一,無需下載軟件,通過瀏覽器即可完成信息交流,網(wǎng)頁即 時聊天系統(tǒng)有著不錯的應(yīng)用環(huán)境和廣大的市場前景。




本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉