电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:9日期: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
相關文章:
主站蜘蛛池模板: 东莞市天进机械有限公司-钉箱机-粘箱机-糊箱机-打钉机认准东莞天进机械-厂家直供更放心! | SRRC认证_电磁兼容_EMC测试整改_FCC认证_SDOC认证-深圳市环测威检测技术有限公司 | 谷歌关键词优化-外贸网站优化-Google SEO小语种推广-思亿欧外贸快车 | 亳州网络公司 - 亳州网站制作 - 亳州网站建设 - 亳州易天科技 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 翰墨AI智能写作助手官网_人工智能问答在线AI写作免费一键生成 | 安徽净化工程设计_无尘净化车间工程_合肥净化实验室_安徽创世环境科技有限公司 | 自清洗过滤器_全自动过滤器_全自动反冲洗过滤器_量子过滤器-滑漮滴 | 药品冷藏箱厂家_低温冰箱_洁净工作台-济南欧莱博电子商务有限公司官网 | 电动葫芦|环链电动葫芦-北京凌鹰名优起重葫芦 | 加气混凝土砌块设备,轻质砖设备,蒸养砖设备,新型墙体设备-河南省杜甫机械制造有限公司 | 通信天线厂家_室分八木天线_对数周期天线_天线加工厂_林创天线源头厂家 | 体坛网_体坛+_体坛周报新闻客户端 | 阻垢剂-反渗透缓蚀阻垢剂厂家-山东鲁东环保科技有限公司 | 手持气象站_便携式气象站_农业气象站_负氧离子监测站-山东万象环境 | 合肥卓创建筑装饰,专业办公室装饰、商业空间装修与设计。 | 一体化污水处理设备_生活污水处理设备_全自动加药装置厂家-明基环保 | 品牌设计_VI设计_电影海报设计_包装设计_LOGO设计-Bacross新越品牌顾问 | 洁净实验室工程-成都手术室净化-无尘车间装修-四川华锐净化公司-洁净室专业厂家 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 综合管廊模具_生态,阶梯护坡模具_检查井模具制造-致宏模具厂家 | 微水泥_硅藻泥_艺术涂料_艺术漆_艺术漆加盟-青岛泥之韵环保壁材 武汉EPS线条_EPS装饰线条_EPS构件_湖北博欧EPS线条厂家 | 海外仓系统|国际货代系统|退货换标系统|WMS仓储系统|海豚云 | 电缆接头_防水接头_电缆防水接头 - 乐清市新豪电气有限公司 | BESWICK球阀,BESWICK接头,BURKERT膜片阀,美国SEL继电器-东莞市广联自动化科技有限公司 | 东莞爱加真空科技有限公司-进口真空镀膜机|真空镀膜设备|Polycold维修厂家 | 承插管件_不锈钢承插管件_锻钢高压管件-温州科正阀门管件有限公司 | 播音主持培训-中影人教育播音主持学苑「官网」-中国艺考界的贵族学校 | 智能监控-安防监控-监控系统安装-弱电工程公司_成都万全电子 | 密集柜_档案密集柜_智能密集架_密集柜厂家_密集架价格-智英伟业 密集架-密集柜厂家-智能档案密集架-自动选层柜订做-河北风顺金属制品有限公司 | 利浦顿蒸汽发生器厂家-电蒸汽发生器/燃气蒸汽发生器_湖北利浦顿热能科技有限公司官网 | 冷水机,风冷冷水机,水冷冷水机,螺杆冷水机专业制造商-上海祝松机械有限公司 | 冲锋衣滑雪服厂家-冲锋衣定制工厂-滑雪服加工厂-广东睿牛户外(S-GERT) | ph计,实验室ph计,台式ph计,实验室酸度计,台式酸度计 | 单机除尘器 骨架-脉冲除尘器设备生产厂家-润天环保设备 | 校园文化空间设计-数字化|中医文化空间设计-党建|法治廉政主题文化空间施工-山东锐尚文化传播公司 | 永嘉县奥阳陶瓷阀门有限公司| 广州各区危化证办理_危险化学品经营许可证代办 | 广州各区危化证办理_危险化学品经营许可证代办 | ★店家乐|服装销售管理软件|服装店收银系统|内衣店鞋店进销存软件|连锁店管理软件|收银软件手机版|会员管理系统-手机版,云版,App |