日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

PHP聊天室應用實現方法思路

瀏覽:73日期:2022-09-12 17:47:02
介紹

聊天應用程序在網上非常常見。開發人員在構建這類應用程序時的選擇也很多。這篇文章介紹了如何實現基于PHP-AJAX的聊天應用程序,并且不需要刷新頁面就可以發送和接收消息。

核心邏輯

在定義應用程序的核心功能之前,先來看一看聊天應用程序的基本外觀,如以下截圖所示:

PHP聊天室應用實現方法思路

通過聊天窗口底部的輸入框輸入聊天文本。點擊Send按鈕,就開始執行函數set_chat_msg。這是一個基于Ajax的函數,因此無需刷新頁面就可以將聊天文本發送到服務器。程序在服務器中執行chat_send_ajax.php以及用戶名和聊天文本。

//// Set Chat Message//function set_chat_msg(){ if(typeof XMLHttpRequest != 'undefined') {oxmlHttpSend = new XMLHttpRequest(); } else if (window.ActiveXObject) { oxmlHttpSend = new ActiveXObject('Microsoft.XMLHttp'); } if(oxmlHttpSend == null) { alert('Browser does not support XML Http Request'); return; } var url = 'chat_send_ajax.php'; var strname='noname'; var strmsg=''; if (document.getElementById('txtname') != null) {strname = document.getElementById('txtname').value;document.getElementById('txtname').readOnly=true; } if (document.getElementById('txtmsg') != null) {strmsg = document.getElementById('txtmsg').value;document.getElementById('txtmsg').value = ''; } url += '?name=' + strname + '&msg=' + strmsg; oxmlHttpSend.open('GET',url,true); oxmlHttpSend.send(null);}

PHP模塊從Query String(查詢字符串)中接收表單數據,更新到命名為chat的數據庫表中。chat數據庫表有命名為ID、USERNAME、CHATDATE和MSG的列。ID字段是自動遞增字段,所以這個ID字段的賦值將自動遞增。當前的日期和時間,會更新到CHATDATE列。

require_once(’dbconnect.php’);db_connect();$msg = $_GET['msg'];$dt = date('Y-m-d H:i:s');$user = $_GET['name'];$sql='INSERT INTO chat(USERNAME,CHATDATE,MSG) ' . 'values(' . quote($user) . ',' . quote($dt) . ',' . quote($msg) . ');'; echo $sql;$result = mysql_query($sql);if(!$result){ throw new Exception(’Query failed: ’ . mysql_error()); exit();}

為了接收來自數據庫表中所有用戶的聊天消息,timer函數被設置為循環5秒調用以下的JavaScript命令,即每隔5秒時間執行get_chat_msg函數。

var t = setInterval(function(){get_chat_msg()},5000);

get_chat_msg是一個基于Ajax的函數。它執行chat_recv_ajax.php程序以獲得來自于數據庫表的聊天信息。在onreadystatechange屬性中,另一個JavaScript 函數get_chat_msg_result被連接起來。在返回來自于數據庫表中的聊天消息的同時,程序控制進入到get_chat_msg_result函數。

//// General Ajax Call//var oxmlHttp;var oxmlHttpSend;function get_chat_msg(){ if(typeof XMLHttpRequest != 'undefined') {oxmlHttp = new XMLHttpRequest(); } else if (window.ActiveXObject) { oxmlHttp = new ActiveXObject('Microsoft.XMLHttp'); } if(oxmlHttp == null) {alert('Browser does not support XML Http Request'); return; } oxmlHttp.onreadystatechange = get_chat_msg_result; oxmlHttp.open('GET','chat_recv_ajax.php',true); oxmlHttp.send(null);}

在chat_recv_ajax.php程序中,來自于用戶的聊天消息會通過SQL select命令進行收集。為了限制行數,在SQL查詢中還給出了限制子句(limit 200),即要求聊天數據庫表中的最后200行。所獲得的消息再返回給Ajax函數,用于在聊天窗口中顯示內容。

require_once(’dbconnect.php’);db_connect();$sql = 'SELECT *, date_format(chatdate,’%d-%m-%Y %r’) as cdt from chat order by ID desc limit 200';$sql = 'SELECT * FROM (' . $sql . ') as ch order by ID';$result = mysql_query($sql) or die(’Query failed: ’ . mysql_error());// Update Row Information$msg='';while ($line = mysql_fetch_array($result, MYSQL_ASSOC)){ $msg = $msg . '' .'' .'';}$msg=$msg . '<table . 'font-size: 10pt;' border='0'> <tbody><tr><td>' . $line['cdt'] . ' </td><td>' . $line['username'] . ': </td><td>' . $line['msg'] . '</td></tr></tbody></table>';echo $msg;

數據準備就緒的同時,JavaScript函數會收集來自于PHP接收到的數據。這些數據將被安排置于DIV標簽內。oxmlHttp.responseText會保留從PHP程序接收到的聊天消息,并復制到DIV標簽的document.getElementById(“DIV_CHAT”).innerHTML屬性。

function get_chat_msg_result(t){ if(oxmlHttp.readyState==4 || oxmlHttp.readyState=='complete') {if (document.getElementById('DIV_CHAT') != null){ document.getElementById('DIV_CHAT').innerHTML = oxmlHttp.responseText; oxmlHttp = null;}var scrollDiv = document.getElementById('DIV_CHAT');scrollDiv.scrollTop = scrollDiv.scrollHeight; }}

下面的SQL CREATE TABLE命令可用于創建名為chat的數據庫表。所有由用戶輸入的信息都會進入到數據庫表中。

create table chat( id bigint AUTO_INCREMENT,username varchar(20), chatdate datetime,msg varchar(500), primary key(id));興趣點

這段用于實現聊天應用程序的代碼非常有意思。它可以改進成為一個完全成熟的HTTP聊天應用程序。創建該應用程序的邏輯也非常簡單。即使是初學者理解起來也不會有任何困難。

許可證

這篇文章,以及任何相關的源代碼和文件,都獲得了The Code Project Open License (CPOL)的許可。

標簽: PHP
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
蜜桃一区二区三区在线观看| 日韩午夜视频在线| 精品久久中文| 精品亚洲精品| 亚洲精品乱码日韩| 欧美激情国产在线| 日韩激情网站| 亚洲一区二区三区高清| 国产精品伦一区二区| 亚洲日韩中文字幕一区| 久久久久一区| 在线人成日本视频| 麻豆mv在线观看| 国产精东传媒成人av电影| 老牛国内精品亚洲成av人片| 中文字幕一区二区三区日韩精品| 日本亚州欧洲精品不卡| 你懂的国产精品| а√天堂8资源中文在线| 免费国产自久久久久三四区久久 | 成人国产综合| 日本不卡不码高清免费观看| 欧美性www| 日本vs亚洲vs韩国一区三区二区| 91久久久久| 女人av一区| 人人爽香蕉精品| 国产亚洲精品v| 精品国产91| 色综合五月天| 欧洲在线一区| 成人久久久久| 日本国产精品| 婷婷精品久久久久久久久久不卡| 国产精品超碰| 婷婷色综合网| 国产伦久视频在线观看| 黄页网站一区| 精品国产99| 亚洲精选久久| 日韩一区二区三区免费视频| 一区免费在线| 久久裸体视频| 最新国产精品| 国产日韩一区二区三区在线| 国产精品66| 成人av二区| 牛牛精品成人免费视频| 亚洲专区一区| 日韩精品久久理论片| 捆绑调教日本一区二区三区| 久久福利精品| 日韩av片子| 中文亚洲免费| 免费看一区二区三区| 国产一二在线播放| 最新亚洲国产| 亚洲精一区二区三区| 亚洲综合精品| 日本在线精品| 日韩毛片一区| 国产综合激情| 91欧美日韩| 久久精品国产亚洲aⅴ| 欧美日韩一区二区三区四区在线观看 | 免费成人在线视频观看| 蜜桃成人av| 国产一区2区| 欧美一区精品| 久久精品国产亚洲夜色av网站| 美女日韩在线中文字幕| 另类综合日韩欧美亚洲| 电影天堂国产精品| 丝瓜av网站精品一区二区 | 亚洲成人二区| 欧美中文字幕一区二区| 免费日韩视频| 欧美日韩一区二区高清| 日韩高清三区| 亚洲神马久久| 国产一区二区三区四区大秀| 国产精品婷婷| 欧美一区网站| 久久国产精品亚洲77777| 亚洲欧洲一区二区天堂久久| 精品国产乱码久久久久久1区2匹| 国产日产高清欧美一区二区三区| 免费日韩av片| 毛片在线网站| 国产99在线| 99成人在线视频| 亚洲欧美日韩高清在线| 伊人久久亚洲美女图片| 免费日韩视频| 日韩精品免费视频一区二区三区| 日韩视频二区| 综合一区二区三区| 色婷婷成人网| 日本久久成人网| 伊人久久成人| 亚洲在线久久| 国产欧美二区| 久久婷婷久久| 亚洲精品**中文毛片| 久久精品官网| 日韩亚洲精品在线观看| 国产欧美一区二区三区米奇| 亚洲不卡视频| 91综合网人人| 99成人在线| 色婷婷成人网| 久久久精品区| 少妇久久久久| 亚洲精品福利| 精品99在线| 欧美日韩激情| 国产精品视频3p| 欧美91福利在线观看| 免费观看久久久4p| 国产精品极品国产中出| 国产亚洲一区二区手机在线观看 | 视频在线观看91| 国产日韩欧美中文在线| bbw在线视频| 91亚洲精品在看在线观看高清| 中文字幕人成乱码在线观看| 日韩欧美一区二区三区在线观看 | 欧美一区自拍| 自拍日韩欧美| 国产成人精品福利| 亚洲精品成a人ⅴ香蕉片| 美女福利一区二区三区| 国产麻豆一区二区三区| 亚洲免费激情| 国产中文在线播放| 91伊人久久| 久久亚洲二区| 99精品视频在线| 国产精品v亚洲精品v日韩精品| 黄色日韩在线| 中文亚洲免费| 精品免费av一区二区三区| 国产美女亚洲精品7777| 免费久久99精品国产自在现线| 天堂√8在线中文| 久久中文字幕一区二区三区| 日韩精品视频一区二区三区| 99国产精品| 亚洲网站视频| 亚洲综合电影| 国产精品99久久免费观看| 亚洲精品免费观看| 视频在线观看91| 亚洲少妇诱惑| 综合激情网...| 亚洲精品乱码久久久久久蜜桃麻豆| 国产精品手机在线播放| 美女精品视频在线| 欧美日本久久| 国产日韩三级| 国产精品极品在线观看| 国产精品视频首页| 久久av中文| 精品五月天堂| 综合日韩av| 免费av一区| 欧美一级一区| 日本成人在线网站| 国产精品分类| 欧美激情视频一区二区三区免费 | 香蕉久久国产| 日本va欧美va瓶| 久久av综合| 日韩一区二区三区在线免费观看| 在线看片福利| 国产精品xxx在线观看| 久久精品国产亚洲aⅴ| 在线精品亚洲欧美日韩国产| 激情综合在线| 欧美专区18| 国产精品久久久网站| 久久精品一区| 日韩三区在线| 亚洲2区在线| 免费一区二区三区在线视频| 红杏一区二区三区| 成午夜精品一区二区三区软件| 久久麻豆精品| 日韩毛片网站| 涩涩av在线| 日本伊人午夜精品| 国产综合婷婷| 日本久久黄色| 婷婷精品在线观看| 黄色精品网站| 亚洲黄色免费av| 国产精品人人爽人人做我的可爱| 国产欧美激情| | 高清av一区|