# thinksocketio
**Repository Path**: tughluq_admin/thinksocketio
## Basic Information
- **Project Name**: thinksocketio
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 1
- **Forks**: 1
- **Created**: 2020-02-08
- **Last Updated**: 2024-06-11
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
## 简介
一个使用PHPSocket.IO,ThinkPHP5.1,以及JQ实现的聊天室,包括功能有:
- 公频广场聊天
- 自定义用户名
- 一对一私聊
- 公频中私聊信息提醒
- 新用户加入以及离开提醒
- 在线用户列表,人数统计
- 系统主动推送广播,或向指定用户推送消息
## 截图
广场公频聊天:
一对一私聊:
广播推送系统消息:
指定用户推送消息:
## 使用说明
以下说明假定已经为项目`public`目录绑定了域名`test.com`并正确部署服务器,访问`test.com`能看到TP5默认首页。
如果修改了配置或者代码,请重新运行服务端,否则代码不生效。
### 安装
```bash
git clone git@github.com:hsu1943/thinksocketio.git
cd thinksocketio
composer install -vvv
```
### 配置
模板文件`/application/socketio/view/index/index.html`和`/application/socketio/view/index/chat.html`中`socket`修改为你的`socket`服务端地址,默认测试端口2021,端口号可以在`/config/socketio/param.php`中配置。这里是本机测试,用`http://127.0.0.1:2021`。
```bash
var socket = io('http://127.0.0.1:2021');
```
### 使用数据库记录消息:
如果你需要使用数据库存储消息,按照下面的步骤打开配置,打开配置后系统会根据昵称将所有聊天记录写入数据库`msg`表中,包括主动推送的消息;
1. 在`config/database.php`中配置数据库,保证数据库能正确连接;
2. 导入根目录下`msg.sql`到数据库;
3. 在`config/socketio/param.php`中将`save_msg`修改为`true`(默认是`false`,不写入到数据库);
这里说明一下,请保证数据库能正确连接并且里面有正确的表结构(第二步导入表)再进行第三步配置。
### 主动推送系统消息接口
修改配置文件`/config/socketio/param.php`中的配置为监听消息推送地址,这里本地测试,使用本地2121端口;
```bash
return [
'ws' => [
'apiHost' => 'http://127.0.0.1:2121',
],
];
```
该地址即系统推送消息地址,参数:
```html
to:接收人
content:消息
```
两种用法:
1. 其他项目POST或GET请求接口即可推送消息
```html
向username推送系统消息
http://test.com/system?to=username&content=系统推送消息测试
广播消息
http://test.com/system?content=系统推送消息测试
```
`http://test.com/system`这是本项目使用上面的监听地址做的一个消息推送demo,详情看源代码。
2. 本项目中推送系统消息:
已将推送封装在Msg的模型中,使用:
```php
$res = Msg::send($to, $content);
return $res == 'ok' ? '系统消息推送成功' : '系统消息推送失败';
```
## 测试
运行服务端:
```bash
php ./public/server.php
```
这里可以将输出写到某个日志文件中,或者使用`supervisor`来管理服务端。
访问以下地址即可进入公频:
```bash
http://test.com/socketio
```
点击消息列表中的用户名即可进入私聊。
## 更新
* 2019-12-19 增加服务端的输出,以及端口配置项,保存数据库加上错误处理,更新项目README;
* 2019-06-19 增加在线人数统计,在线用户列表,修改昵称,添加系统主动推送接口(广播或私信);
## 开发记录
以下两篇文章是在开发过程中的记录,代码不是最新,最新代码以本项目`github`为准,有问题可以去文章里留言。
[ThinkPHP 5.1+PHPSocket.IO实现websocket搭建聊天室+私聊](https://beltxman.com/archives/2329.html "ThinkPHP 5.1+PHPSocket.IO实现websocket搭建聊天室+私聊")
[ThinkPHP 5.1下使用PHPSocket.IO实现websocket通讯](https://beltxman.com/archives/1885.html "ThinkPHP 5.1下使用PHPSocket.IO实现websocket通讯")
## 感谢
* top-think/framework
* walkor/phpsocket.io
* walkor/web-msg-sender