[开源篇] 基于 workerman + Thinkphp5 搭建的即时通讯系统
特别说明:
为了简化安装,简易部署,数据库配置已经预设并且可以直接使用,无需修改!为保护公司数据库安全,故无法直接提供代码。对此 demo 有兴趣的同学可以通过下面的链接成为仓库的开发者。
- 当前链接状态需要被审核,任何人可通过此链接加入仓库, 当前链接有效期为 3 天
在线演示
1.列表页:http://juda.yunmell.com/chat/public/index.php/index/index/lists?fromid=10
2.聊天页面:
http://juda.yunmell.com/chat/public/index.php/index/index/index?fromid=10&toid=50
url 参数说明:
1. fromid: 消息发送方用户id
2. toid: 消息接收方用户id
系统内置用户:
[from|to]id 分别为10,50,60 共三个用户,其他id用户无内容。
介绍
基于 workerman + Thinkphp5 搭建的即时通讯系统
已实现功能:
1. 一对一单聊
2. 列表页消息实时更新(略有延迟)
软件架构
www WEB部署目录(或者子目录)
├─application 应用目录
│
├─public WEB目录(对外访问目录)
│ ├─index.php 入口文件
│ ├─router.php 快速测试文件
│ └─.htaccess 用于apache的重写
│
├─thinkphp 框架系统目录
│ ├─lang 语言文件目录
│ ├─library 框架类库目录
│ │ ├─think Think类库包目录
│ │ └─traits 系统Trait目录
│ │
│ ├─tpl 系统模板目录
│ ├─base.php 基础定义文件
│ ├─console.php 控制台入口文件
│ ├─convention.php 框架惯例配置文件
│ ├─helper.php 助手函数文件
│ ├─phpunit.xml phpunit配置文件
│ └─start.php 框架入口文件
│
├─extend 扩展类库目录
├─runtime 应用的运行时目录(可写,可定制)
├─vendor 第三方类库目录(Composer依赖库)
| |
| |——GatewayWorker-for-win workerman主目录
│ │ |
│ │ └─start.php 框架启动文件
|
├─build.php 自动生成定义文件(参考)
├─composer.json composer 定义文件
├─LICENSE.txt 授权说明文件
├─README.md README 文件
├─think 命令行入口文件
安装教程
WEB集成环境使用 phpstudy,假设 phpstydy 安装路径位于
D:\phpstudy_pro
。其他集成工具自行处理。
1.进入 D:\phpstudy_pro\WWW
目录,执行 git clone git@gitee.com:symol/im_workerman.git
或者 直接下载zip包
2.通过 phpstudy 将新建的网站的 物理路径 指向 D:\phpstudy_pro\WWW\im_workerman\public
3.配置本地访问域名,如下面的 im.symbol.com;
4.确认提交即安装完毕,准备使用。
使用说明
1.开启 workerman 服务:进入 vendor/GatewayWorker-for-win
目录,执行 start_for_win.bat
启动服务;
2.访问 http://im.symbol.com/index.php/index/index/lists?fromid=10
显示最近的会话列表(推荐F12切换到手机尺寸);
3.点击好友列表进入聊天页面(http://im.symbol.com/index.php/index/index/lists?fromid=10&toid=50
)
参与贡献
近期功能安排:
- 登录注册完善
- 代码 review,修复已知 bug
性能优化点:
- 列表页加载刷新问题,最好是用户无感知的刷新(实现思路:目前列表的自动刷新是通过websocket+http的get方式实现的,每当websocket有新消息传递时,前端页面通过ajax重新刷新页面,所以会有明显的闪动。而无感知的刷新是在后台构造好数据【用户+最后一条消息内容及时间】,通过websocket传递给前端,而不需要走ajax)
1.Fork 本仓库
2.新建 Feat_xxx 分支
3.提交代码
4.新建 Pull Request
诚邀
欢迎各位小伙伴一起协作、探讨,一起打造 IM 通讯系统。