php redis 实时聊天,PHP用swoole+websocket和redis实现web一对一聊天

本文介绍了如何使用PHP的Swoole扩展和WebSocket,结合Redis实现一个实时聊天系统。当用户通过WebSocket连接时,他们的连接与用户账号绑定在Redis中。离线消息通过MySQL存储,用户上线后从离线消息池取出并发送。详细代码包括服务器端的WebSocket处理和客户端的交互逻辑,以及数据表结构设计。
摘要由CSDN通过智能技术生成

Redis 实现每个连接websocket的服务都唯一绑定一个用户。通过 用户账号 = websocket fd 存到redis中。

Mysql 实现离线消息池。如果一个用户不在线,则其他用户发送给他的消息暂时存储在mysql。待该用户上线时,再从离线消息池取出发送。

具体参考代码和相应注释:

$server = new swoole_websocket_server("0.0.0.0", 9052);

$redis = new Redis();

$redis->connect('127.0.0.1', 6379);

$db = new mysqli('127.0.0.1', 'test', 'test', 'thinkphp5');

$server->on('open', function (swoole_websocket_server $server, $request) {

echo "server: handshake success with fd{$request->fd}\n";//$request->fd 是客户端id

});

$server->on('message', function (swoole_websocket_server $server, $frame) {

$data = json_decode($frame->data,true);

if($data['flag'] == 'init'){

//用户刚连接的时候初始化,每个用户登录时记录该用户对应的fd

$GLOBALS['redis']->set($data['from'], $frame->fd);

//处理发给该用户的离线消息

$sql = "SELECT `from`,content FROM thinkphp5.app_offline WHERE `to`='{$data['from']}' AND `from`='{$data['to']}' AND `status`='0' ORDER BY addtime ASC;";

if ($result = $GLOBALS['db']->query($sql)) {

$re = array();

while ($row = $result->fetch_assoc()) {

array_push($re, $row);

}

$result->free();

foreach($re as $content){

$content = json_encode($content);

$server->push($frame->fd , $content);

}

//设置消息池中的消息为已发送

$sql = "UPDATE thinkphp5.app_offline SET `status`=1 WHERE `to`='{$data['from']}' AND `from`='{$data['to']}';";

$GLOBALS['db']->query($sql);

}

}else if($data['flag'] == 'msg'){

//非初始化的信息发送,一对一聊天,根据每个用户对应的fd发给特定用户

$tofd = $GLOBALS['redis']->get($data['to']); //消息要发给谁

$fds = []; //所有在线的用户(打开聊天窗口

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值