php网站聊天,php网站怎么写一个聊天

cd26a9e5f1abfd3706d4463c9fd28b75.png

php网站怎么写一个聊天

网页聊天室我们可以使用多种方式实现,比如websocket,或是使用第三方的聊天服务,下面介绍一种最简单的方式,不断刷新页面获取信息。

1、数据库建立create table chat (

chattime datetime,

nick char(10),

words char(150)

);

login.php

用户登录 //点击登录后跳转到main.php,并将输入的数据用post的方式发送过去

main.php<?php

session_start();

$_SESSION['nick'] = $_POST['nick']; //获取login.php发送过来的数据,也就是用户昵称,并将它保存在session中用于对用户进行跟踪

?>

// 聊天信息展示区

//发言区

speak.php

发言

session_start(); //如果设置北京时间,需要加上 date_default_timezone_set('PRC');

if ($_POST['words']) {

$conn = mysql_connect("127.0.0.1","root","******"); //连接数据库

mysql_select_db("yuema", $conn);

$time = date(y).date(m).date(d).date(h).date(i).date(s); //当前时间

$nick = $_SESSION['nick'];

$words = $_POST['words'];

$str = "insert into chat(chattime, nick, words) values('$time', '$nick', '$words');";

mysql_query($str, $conn); //将用户名,时间和发言内容进行插入

mysql_close($conn);

}

?>

cdisplay.php

显示用户发言

//设置每隔5秒钟刷新一次

$conn = mysql_connect("127.0.0.1", "root", "******");

mysql_select_db("yuema", $conn);

$str = "select * from chat order by chattime;";

$result = mysql_query($str, $conn);

$rows = mysql_num_rows($result);

mysql_data_seek($result, $rows-15); //取最近插入的15条数据

if ($rows<15)

$l = $rows;

else

$l = 15;

for ($i = 1; $i <= $l; $i++) { //输出这15条数据

list($chattime, $nick, $words) = mysql_fetch_row($result);

echo $chattime;

echo " ".$nick." ";

echo $words;

echo "
";

}

?>

结果展示

5401b9d9b0b2f7e4ba46f2430590d308.png

2. ajax获取,不刷新页面

login.php

用户登录 //点击登录后跳转到main.php,并将输入的数据用post的方式发送过去

main.php<?php

session_start();

$_SESSION['nick'] = $_POST['nick']; //获取login.php发送过来的数据,也就是用户昵称,并将它保存在session中用于对用户进行跟踪

?>

// 聊天信息展示区

//发言区

speak.php

发言

session_start(); //如果设置北京时间,需要加上 date_default_timezone_set('PRC');

if ($_POST['words']) {

$conn = mysql_connect("127.0.0.1","root","******"); //连接数据库

mysql_select_db("yuema", $conn);

$time = date(y).date(m).date(d).date(h).date(i).date(s); //当前时间

$nick = $_SESSION['nick'];

$words = $_POST['words'];

$str = "insert into chat(chattime, nick, words) values('$time', '$nick', '$words');";

mysql_query($str, $conn); //将用户名,时间和发言内容进行插入

mysql_close($conn);

}

?>

cdisplay.php

显示用户发言

//jquery库,jquery.js可以在网上下载

setInterval('show()', 3000); // 设置自动刷新时间 3000毫秒也就是3秒钟

function show() {

$.ajax({

url:'server_get.php', //请求发送到server_get.php进行处理

type:'post',

dataType:'html',

error:function() {

alert('请求失败,请稍后再试');

},

success:function(msg) {

$('p').html(msg); //设置body中p标签的内容

}

});

}

server_get.php<?php

$conn = mysql_connect("127.0.0.1", "root", "******");

mysql_select_db("yuema", $conn);

$str = "select * from chat order by chattime;";

$result = mysql_query($str, $conn);

$rows = mysql_num_rows($result);

mysql_data_seek($result, $rows-15);

if ($rows < 15)

$l = $rows;

else

$l = 15;

$string = "";

for ($i = 1; $i <= $l; $i++) {

list($chattime, $nick, $words) = mysql_fetch_row($result);

$string.=$chattime;

$string.=" ";

$string.=$nick;

$string.=" ";

$string.=$words;

$string.="
";

}

echo $string;

?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值