php_D3_“简易聊天室 ”实现的关键技术 详解

时间:2023-12-29 21:58:08

                  PHP+MySQL实现Internet上一个简易聊天室的关键技术

 系统目标:

聊天室使用数据库汇集每个人的发言,并可将数据库内的发言信息显示在页面,让每个用户都可以看到,具体功能如下:

a.用户登录:用户发言时显示其登录名信息

b.用户发言:用户输入说的话

c.显示发言信息:用户浏览所有发言信息

设计思路:

(1).建立聊天室数据库及相关数据表

(2).实现用户登录页面(login.php)

(3).实现发言页面(speak.php)

(4).实现发言显示页面(chat_display.php)

(5).实现主页面(main.php)

关键技术:

1.自动刷新页面:

如果要想使页面每隔一定时间就自动刷新,其实现方法是在HTML的<HEAD>与</HEAD>标签之间加上如下语句:

<meta http-equiv="Refresh" content="秒数";url=跳转的文件或地址>

例如:用户来到页面20s后自动跳转至另一页面new.php,

<meta http-equiv="Refresh" content="20";url=new.php>

2.传递用户名:

在用户登录进入聊天室后,系统应该一直保留其登录信息,以便其发言时使用,可通过Session来实现。session是一种常用的信息存储机制,在此之间要说明本例中的应用。

(1).在用户登录系统时,需要注册一个session变量来存储其登录名信息:

1 <?php
2 session_start(); //装载session库,一定要放在首行
3 $user_name=$_POST["nick"];
4 session_register("user_name") ; //注册 $user_name 变量
5 ?>

其中,第2行打开session功能,第3行得到页面表单上用户输入的昵称信息,第4行注册session变量user_name.

(2).在用户发言的页面上,在其发言时,获取session变量user_name,并将其值连同其发言内容存入数据库:

1 <?php session_start();
2 ···
3 $author=$_SESSION["user_name"];
4 ··· //把author信息存入数据库
5 ?>

这样,在用户离开系统前,系统将一直利用session来保存登录名信息,可以随时在需要时使用。

3.显示最新发言:

简易聊天室另一个需要解决的问题是,在显示发言信息时,由于发言信息很多,不能将其全部显示出来,而只显示最新的一定数量的发言信息。这可以通过对发言信息按发言时间顺序排序递增,并选择最后的部分发言实现。

下面是在页面显示最新的15条发言信息:

 1 @mysql_data_seek($resut,$rows-15); //移动记录指针到前15笔记录
2 if ($rows<15)
3 $l=$rows;
4 else
5 $l=15; //记录总数小于15,则最多为该记录数
6 for ($i=1;$i<=$l;$i++) //通过循环读取发言信息
7 {
8 list($cid,$author,$create_time,$text)=mysql_fetch_row($result);
9 echo $create_time;
10 echo " ";
11 echo "【".$author."】";
12 echo"说到:" ;
13 echo $text;
14 echo "<BR>"; //输出留言内容
15 }

其中,第1行$result 为查询所有留言得到的记录集,通过mysql_data_seek()命令来移动其记录游标到倒数第15条记录上;然后6~15行输出至多15条发言。

另外,数据库也没必要保留全部用户发言信息,否则会是数据库讯速膨胀。可以使用一个策略:只保留最近一定数量的发言,而把其他过期发言及时删除。

系统实现:

(1).创建数据库:

CREATE DATABASE 'my_chat';

(2).创建chat表:

 -- 创建chat表:
CREATE TABLE `chat` (
`cid` INT NOT NULL AUTO_INCREMENT ,
`author` VARCHAR( 50 ) NOT NULL ,
`create_time` TIME NOT NULL ,
`text` BLOB NOT NULL ,
PRIMARY KEY ( `cid` )
);