websocket php框架,GitHub - xiaochengfu/websocket-swoole: 基于swoole实现websocket实时通信,推送服务,适用thinkphp/yii2/...

websocket-Swoole php框架扩展

扩展说明

基于swoole开发的websocket实时推送、主动推送、长连接扩展,应用于php的各类框架,如thinkphp,yii2,laravel等

如何使用

安装

composer require xiaochengfu/swoole-websocket

配置

1.将params_swoole.php.default配置文件放到你框架配置文件夹下

推荐放到config下:

laravel、thinkphp5/6放到config目录下

yii2放到common/config目录下

2.修改配置文件

如何修改,配置文件中有具体说明

启动

根据每个框架的自定义命令,设置对应的指令即可,以启动为例

$setting = config('params.swoole');//框架获取配置的方法,各有不同

$swoole = new SwooleService($setting);

$swoole->serviceStart();

扩展支持

a.启动服务 serviceStart

b.查看服务状态 serviceStats

c.查看进程列表 serviceList

d.停止服务 serviceStop

场景测试

1.连接socket

访问http://www.websocket-test.com,输入ip:9512,进行连接测试

2.测试推送

推送通过http请求触发,在你要触发推送的action中,添加

$swoole = new \xiaochengfu\swoole\Swoole(config('params.swoole'));

$swoole->pushMsg(1,['hello','world']);

//注意pushMsg($fd,$data)

//fd 这里可用刚连接的客户端1

//data 类型为数组

正确的话,你将在刚连接的浏览器客户端中接收到推送消息

测试实时消息通信

这里采用callback回调的方式,可灵活的嵌入逻辑,只需要把SwooleCallback.php

文件放到vendor外的任何地方,通过修改命名空间来访问,这里仅把SwooleCallback.php文件当作测试回调文件!

客户端发送消息格式如下:

{"data":{"namespace":"xiaochengfu\\swoole\\SwooleCallback","function":"test","params":{"a":1}}}

---敲黑板---

a.发送的消息必须为字符串

b.格式说明

namespace 为回调文件的名字空间

function 为回调文件内的方法,必须为静态方法

params 为方法的参数

正确的话,socket客户端将立即收到服务端返回的消息

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值