博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
laravel+swoole之websocket消息推送
阅读量:7233 次
发布时间:2019-06-29

本文共 4617 字,大约阅读时间需要 15 分钟。

1.首先安装 swoole 扩展 Swoole-1.x 需要 PHP-5.3.10 或更高版本 Swoole-2.x 需要 PHP-7.0.0 或更高版本

公司环境是 php5.6.31所以比较麻烦需要编译安装,7以上直接使用命令 (pecl install swoole)

wget https://github.com/swoole/swoole-src/archive/v1.10.1.tar.gz tar -zxvf v1.10.1.tar.gz cd swoole-src-1.10.1 phpize ./configure --with-php-config=/usr/local/php/bin/php-config make && make install

然后在 php.ini 添加 swoole.so 扩展即可 2.使用 laravel 的 artisan 创建命令 php artisan make:command Swoole #创建一个命令 swoole 并会在 app/Console/Commands 增加一个 Swoole.php 的文件

Commands\Swoole::Class #在 Kernel.php 里增加命令列表 3.运行 socket 服务 1.编辑 app/Console/Command 里的 Swoole.php 文件

argument('action'); switch ($action) { case 'close': break; default: $this->start(); break; } } public function start() { //创建 websocket 服务器对象,监听 0.0.0.0:9502 端口 $this->ws = new \swoole_websocket_server("0.0.0.0", 9502); //监听 WebSocket 连接打开事件 $this->ws->on('open', function ($ws, $request) { var_dump($request->fd . "连接成功"); // $ws->push($request->fd, "hello, welcome\n"); }); //监听 WebSocket 消息事件 $this->ws->on('message', function ($ws, $frame) { // echo "Message: {
$frame->data}\n"; // $ws->push($frame->fd, "server: {
$frame->data}"); // var_dump($ws->connection_info($frame->fd)); //fd 绑定客户端传过来的标识 uid $ws->bind($frame->fd, $frame->data); }); $this->ws->on('request', function ($request, $response) { // 接收 http 请求从 post 获取参数 // 获取所有连接的客户端,验证 uid 给指定用户推送消息 // token 验证推送来源,避免恶意访问 if ($request->post['token'] == ### ) {
$clients = $this->ws->getClientList(); $clientId = []; foreach ($clients as $value) { $clientInfo = $this->ws->connection_info($value); if (array_key_exists('uid', $clientInfo) && $clientInfo['uid'] == $request->post['s_id']) { $clientId[] = $value; } } if (!empty($clientId)) { foreach ($clientId as $v) { $this->ws->push($v, $request->post['info']); } } } }); //监听 WebSocket 连接关闭事件 $this->ws->on('close', function ($ws, $fd) { echo "client:{
$fd} is closed\n"; }); $this->ws->start(); }}【注】此处为了结合 app 上传数据时使用 curl 触发 request 回调通知 web 端的实例所以使用了 httpserver 的 onrequest 事件,如果以后有更好的办法去触发服务端实时主动推送。2.编辑 html
$('#test').click(function(){ if("WebSocket" in window){ console.log("您的浏览器支持 websocket\n"); var ws = new WebSocket("ws://66.66.66.66:9502");//创建 websocket 对象 ws.onopen = function(){ // ws.send("连接已建立\n"); ws.send($("#content").attr("js-sid")); console.log("数据发送中"); } ws.onmessage = function(evt){ var recv_msg = evt.data; console.log("接受到的数据为:"+recv_msg); } ws.onerror = function(evt,e){ console.log("错误信息为"+e); } ws.onclose = function(){ console.log("连接已关闭"); } }else{ console.log("您的浏览器不支持 websocket\n"); } });3.curl 方法(调用就行)public function swooletest($param = ['s_id'=>2, 'info'=>'info']) { $param['token'] = ###; $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, "http://127.0.0.1:9502"); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HEADER, 1); curl_setopt($ch, CURLOPT_POST, 1); //设置 post 数据 $post_data = $param; curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data); curl_exec($ch); curl_close($ch); } 4.测试的时候直接在 laravel 的 artisan 所在目录使用命令 php artisan swoole 即可启动 socket 服务,然后页面运行客户端,最后调用 curl 推送数据。4.成功之后用 supervisor 守护 swoole 命令,或者 nohup 后台启动。supervisor 配置麻烦不过可以自动重启,nohup 一条命令解决nohup php artisan swoole & #一条命令解决此处说明几个问题1.此处我采用的是 bind 方法,当客户端连接的时候 send 一个 uid 过来,然后在服务端处理的时候把 uid 和 fd 绑定在一起,当你想向某个客户端发送数据时传一个 uid,通过 uid 找到 fd 进行指定发送,但是此处我用的是遍历 getClientList 所有连接用户(方法欠佳)的信息 connection_info 进行判定。希望能改善这种方法2.因为是 curl 访问 httpserver 的形式,所以为了避免恶意访问,加一个 token 验证。3.推送的信息转换成 json 再传,即 info 值4.本实例的账户可能会在多个终端登录,有多个 fd 绑定 uid,所以遍历推送 push复制代码

阅读原文请访问以下链接 :

转载地址:http://dxlfm.baihongyu.com/

你可能感兴趣的文章
2015 计蒜之道 初赛(4)爱奇艺的自制节目(枚举 贪心)
查看>>
小程序页面可以放置转发按钮,同时开放了微信运动步数背景音乐播放等更多基础能力...
查看>>
如何实现dede首页栏目文章指定调用
查看>>
bbed改动undo段状态(ORA-01578)
查看>>
vijos- P1383盗窃-黑珍珠 (python + 代码优化)
查看>>
python之 前端HTML/CSS基础知识学习笔记
查看>>
终结者:负载均衡之Nginx(一)
查看>>
Python基础之控制流
查看>>
超慢速移动动画使用CSS3实现流畅效果
查看>>
为什么String类是不可变的?
查看>>
Maven介绍,包括作用、核心概念、用法、常用命令、扩展及配置
查看>>
Hibernate(十五):QBC检索、本地SQL检索和HQL删除
查看>>
BZOJ 1091([SCOI2003]分割多边形-分割直线)
查看>>
<html>
查看>>
淘宝中间的一像素线(手机端)
查看>>
iOS开发 之 不要告诉我你真的懂isEqual与hash!
查看>>
vscode: Visual Studio Code 常用快捷键1
查看>>
多线程(7)多线程中的异常处理
查看>>
(转)基于MVC4+EasyUI的Web开发框架经验总结(12)--利用Jquery处理数据交互的几种方式...
查看>>
java多线程之 ---- 线程死锁
查看>>