zoukankan      html  css  js  c++  java
  • thinkphp5.0整合workerman实现简单聊天室

    具体配置请看上一篇文档。

    Worker.php 文档代码
    <?php
    
    namespace apphttpcontroller;
    
    use thinkworkerServer;
    
    class Worker extends Server
    {
        protected $socket = 'websocket://127.0.0.1:2346';
        protected $processes = 1;
        /**
         * 收到信息
         * @param $connection
         * @param $data
         */
        public function onMessage($connection, $data)
        {
    
            $worker = $this->worker;
            $id = $connection->id;
            foreach ($worker->connections as $connection){
                $connection->send($id .'说:'.$data);
            }
        }
    
        /**
         * 当连接建立时触发的回调函数
         * @param $connection
         */
        public function onConnect($connection)
        {
    
        }
    
        /**
         * 当连接断开时触发的回调函数
         * @param $connection
         */
        public function onClose($connection)
        {
    
        }
    
        /**
         * 当客户端的连接上发生错误时触发
         * @param $connection
         * @param $code
         * @param $msg
         */
        public function onError($connection, $code, $msg)
        {
            echo "error $code $msg
    ";
        }
    
        /**
         * 每个进程启动
         * @param $worker
         */
        public function onWorkerStart($worker)
        {
    
        }
    }
    

    ws_test.html 代码

      

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>workerman</title>
    </head>
    <body>
    
        内容: <input type="text" id="test1" >
        <button type="submit" id="btn" onclick="Submit()" >提交</button>
    
    </body>
    
    <div id="div_box">
    
    </div>
    
    <script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
    <script>
        ws = new WebSocket("ws://127.0.0.1:2346");
        ws.onopen = function() {
        };
    
        function Submit() {
            var uid1 = document.getElementById('test1').value;
            ws.send(uid1);
            document.getElementById('test1').value="";
        }
    
        ws.onmessage = function(e){
            // console.log(e.data);
            $('#div_box').after('<div id="div_box">
    ' +
                '
    ' + e.data +
                '</div>')
        };
    
    </script>
    
    </html>
    

    实测结果

      

  • 相关阅读:
    2. Redis哨兵、复制、集群的设计原理与区别
    1. 详解Redis的存储类型、集群架构、以及应用场景
    博客园主题优化
    【Java基础】Java面试题精选
    【Java集合】——集合类分析总结
    新零售供应链的三大闭环
    Comparable和Comparator比较实现排序 场景分析
    Java基础-枚举类
    Java基础-泛型
    微服务架构~BFF和网关
  • 原文地址:https://www.cnblogs.com/ihuangjianxin/p/13963044.html
Copyright © 2011-2022 走看看