我的编程空间,编程开发者的网络收藏夹
学习永远不晚

laravel使用workerman用户交互、服务器交互的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

laravel使用workerman用户交互、服务器交互的示例分析

                           

laravel使用workerman 用户交互、服务器交互

使用workeman实现浏览器相互通信、服务器浏览器交互

一、安装workerman

composer require workerman/workerman

二、生成命令文件

php artisan make:command Workerman

修改文件

<?phpnamespace App\Console\Commands;use Illuminate\Console\Command;use Workerman\Worker;class Workerman extends Command{    protected $signature = 'Workerman {action} {--daemonize}';    protected $description = 'Command description';    public function __construct()    {        parent::__construct();    }    public function handle()    {        global $argv;//定义全局变量        $arg = $this->argument('action');        $argv[1] = $arg;        $argv[2] = $this->option('daemonize') ? '-d' : '';//该参数是以daemon(守护进程)方式启动        global $text_worker;        // 创建一个Worker监听2345端口,使用websocket协议通讯        $text_worker = new Worker("websocket://0.0.0.0:2345");        $text_worker->uidConnections = array();//在线用户连接对象        $text_worker->uidInfo = array();//在线用户的用户信息        // 启动4个进程对外提供服务        $text_worker->count = 4;        //当启动workerman的时候 触发此方法        $text_worker->onWorkerStart =function(){        };        //当浏览器连接的时候触发此函数        $text_worker->onConnect = function($connection){        };        //向用户发送信息的时候触发        //$connection 当前连接的人的信息 $data 发送的数据        $text_worker->onMessage = function($connection,$data){        };        //浏览器断开链接的时候触发        $text_worker->onClose = function($connection){};    }}

三、启动命令

$ php artisan Workerman start --daemonizeDeprecated: Directive 'track_errors' is deprecated in Unknown on line 0----------------------- WORKERMAN -----------------------------Workerman version:4.0.19          PHP version:7.2.9------------------------ WORKERS -------------------------------worker               listen                              processes statusnone                 websocket://0.0.0.0:2345            4         [ok]

四、浏览器之间通信

1. HTML代码 两个html做交互
 var socket = new WebSocket("ws://localhost:2345//ws");         // 建立连接时触发 建立链接的时候,需要向workerman发送一条指令,告诉他我是谁,使用id或者用户标识作为uid,告诉workerman 例如,当前html 用户id是37         socket.onopen = function(event) {            console.log('连接开始...');            socket.send('{"uid":36,"type":'login'}');         }         //workerman发送消息的时候,接收并打印         socket.onmessage = function(event) {            var msg = event.data;            console.log(msg );         }
2. 设置uid

浏览器发来了用户uid,需要workerman保留一下,网上有文档说在触发的时候保存,还有用session的,我试验了没成功,所有用浏览器建立链接的时候,向workerman发送一条信息来创建uid,在workerman上接收一下

//$connection 当前连接的人的信息 $data 发送的数据$text_worker->onMessage = function($connection,$data){      $data = json_decode($data);      if($data['type']=='login'){         $this->create_uid($connection,$data);      }};//创建uid方法 public function create_uid($connection,$data){        global $text_worker;        $connection->uid = $data['uid'];        //保存用户的uid        $text_worker->uidConnections["{$connection->uid}"] = $connection;        //向自己的浏览器返回创建成功的信息        $connection->send("用户:[{$connection->uid}] 创建成功");    }

这时候浏览器就会出现打印信息

laravel使用workerman用户交互、服务器交互的示例分析

3. 向其他用户发送信息

向用户是37的浏览器发送信息

//js代码 socket.send('{"type":"login","to_uid":36,"uid":36,"message":"nihao"}'); //workerman  //$connection 当前连接的人的信息 $data 发送的数据        $text_worker->onMessage = function($connection,$data){            $data = json_decode($data,true);            var_dump($data);            if($data['type']=='login'){                $this->create_uid($connection,$data);            }            if($data['type']=='send_message'){                $this->send_message($connection,$data);            }        };        public function send_message($connection,$data){            global $text_worker;            if(isset($data['to_uid'])){            var_dump($data['to_uid']);            if(isset($text_worker->uidConnections["{$data['to_uid']}"])){                $to_connection=$text_worker->uidConnections["{$data['to_uid']}"];                $to_connection->send($data['uid'].$data['message']);            }        }    }

五、服务器向浏览器通信

1. workeman监听一个本地发送的端口,在启动的时候
//当启动workerman的时候 触发此方法        $text_worker->onWorkerStart =function(){            //监听一个内部端口,用来接收服务器的消息,转发给浏览器            $inner_text_worker = new Worker('Text://127.0.0.1:5678');            $inner_text_worker->onMessage = function($connection_admin, $data)            {                global $text_worker;                // $data数组格式,里面有uid,表示向那个uid的页面推送数据                $data = json_decode($data, true);                var_dump($data);                $to_uid = $data['to_uid'];                var_dump($to_uid);                // 通过workerman,向uid的页面推送数据                // $ret = sendMessageByUid($uid, $buffer);                $connection = $text_worker->uidConnections[$to_uid];                $connection->send($buffer);                // 返回推送结果                $connection_admin->send(true ? 'ok' : 'fail');            };            $inner_text_worker->listen();        };//控制器代码class TestController extends Controller{    public function send(){        $client = stream_socket_client('tcp://127.0.0.1:5678', $errno, $errmsg, 1);        // 推送的数据,包含用户,表示是给这个用户推送        $data = array('uid'=>37,'group'=>'admin', 'message'=>'发送成功啦');        // 发送数据,注意5678端口是Text协议的端口,Text协议需要在数据末尾加上换行符        fwrite($client, json_encode($data)."\n");}}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

laravel使用workerman用户交互、服务器交互的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

laravel使用workerman用户交互、服务器交互的示例分析

laravel使用workerman 用户交互、服务器交互使用workeman实现浏览器相互通信、服务器浏览器交互一、安装workermancomposer require worke
2023-06-14

PHP与JavaScript下Cookie交互使用的示例分析

小编给大家分享一下PHP与JavaScript下Cookie交互使用的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!PHP与JavaScript下Cookie的交互使用下面的例子列出几种情形交互场景,列出JS和ph
2023-06-15

UEFI开发用户交互界面实例分析

这篇“UEFI开发用户交互界面实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“UEFI开发用户交互界面实例分析”文章吧
2023-06-30

Android Service(不和用户交互应用组件)案例分析

Service是在一段不定的时间运行在后台,不和用户交互应用组件。每个Service必须在manifest中 通过来声明。可以通过contect.startservice和contect.bindserverice来启动。
2022-06-06

解析sessionstorage的用途和在网页交互中的使用案例

sessionStorage的作用及其在网页交互中的应用案例解析随着互联网的发展,网页交互对于用户体验的重要性越来越被重视。为了实现更好的网页交互效果,开发人员需要使用一些技术手段来存储和管理用户的数据。sessionStorage就是其
解析sessionstorage的用途和在网页交互中的使用案例
2024-01-15

Golang笔记:使用ssh包作为客户端与SSH服务器交互

文章目录 目的基础说明使用演示单次通讯连续通讯(远程终端) 总结 目的 Golang中可以使用 golang.org/x/crypto/ssh 包作为SSH客户端或者SSH服务使用。这篇文章将简单记录下作为客户端使用的一些内
2023-08-30

node.js中怎么利用postman模拟HTTP服务器与客户端交互

这篇文章给大家介绍node.js中怎么利用postman模拟HTTP服务器与客户端交互,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、node搭建HTTP服务器node中使用 http 模块来创建 HTTP 服务器,
2023-06-20

阿里云服务器能承载多少用户数量的数据信息交互

阿里云服务器能够处理的最大数量的用户数量的数据信息交互,取决于多种因素,包括服务器的性能、存储容量和网络带宽等。以下是一个基于云服务器的一般性计算方法,可以计算出每个用户的数据传输量:假设阿里云服务器的存储容量是10TB,每个用户的数据交互量为2KB,那么10台阿里云服务器就可以承载10*2KB=20000KB的数据信息交互。为了计算每个用户的数据交互量,可以对阿里云服务器的性能进行分析,比如每秒连接数、单台服务器处理能...
2023-10-27

怎么使用Python构建可扩展的社交媒体情感分析服务

本篇文章为大家展示了怎么使用Python构建可扩展的社交媒体情感分析服务,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。探索 Python 库 spaCy 和 vaderSentiment前提条件一个
2023-06-16

使用Go实现TLS服务器和客户端的示例

传输层安全协议(Transport Layer Security,缩写:TLS),及其前身安全套接层(Secure Sockets Layer,缩写:SSL)是一种安全协议,目的是为互联网通信提供安全及数据完整性保障。 SSL包含记录层(R
2022-06-07

使用服务器容器编排工具的案例分析

阐述了服务器容器编排工具的应用范围和优势,并通过多个示例场景详细分析了容器编排工具的实际应用。
使用服务器容器编排工具的案例分析
2024-02-09

SAP C/4HANA Sales Cloud使用OData服务和第三方系统集成的示例分析

这篇文章将为大家详细讲解有关SAP C/4HANA Sales Cloud使用OData服务和第三方系统集成的示例分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。其中明确提到销售云包含SA
2023-06-04

在centos虚拟机搭建服务器测试服务器的性能及上传文件cpu占用率的示例分析

在centos虚拟机搭建服务器测试服务器的性能及上传文件cpu占用率的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、在虚拟机搭建服务器,虚拟机为ce
2023-06-06

编程热搜

目录