php即时聊天数据库设计入门经典教程_php_D3_“简易聊天室 ”实现的关键技术 详解...

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

系统目标:

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

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

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

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

设计思路:

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

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

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

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

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

关键技术:

1.自动刷新页面:

如果要想使页面每隔一定时间就自动刷新,其实现方法是在HTML的

与标签之间加上如下语句:

例如:用户来到页面20s后自动跳转至另一页面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 "
"; //输出留言内容

15 }

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

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

系统实现:

(1).创建数据库:

CREATE DATABASE 'my_chat';

(2).创建chat表:

1 --创建chat表:2 CREATE TABLE `chat` (3 `cid` INT NOT NULL AUTO_INCREMENT ,

4 `author` VARCHAR( 50 ) NOT NULL ,

5 `create_time` TIME NOT NULL ,

6 `text` BLOB NOT NULL ,

7 PRIMARY KEY( `cid` )8 );

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值