您好,欢迎访问一九零五行业门户网

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

下面由laravel教程栏目给大家介绍laravel使用workerman用户交互、服务器交互,希望对需要的朋友有所帮助!
laravel使用workerman 用户交互、服务器交互
使用workeman实现浏览器相互通信、服务器浏览器交互
一、安装workermancomposer 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}] 创建成功);    }
这时候浏览器就会出现打印信息
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);}}
结语有不足之处,请大家指正!谢谢!
以上就是解析laravel使用workerman用户交互、服务器交互的详细内容。
其它类似信息

推荐信息