thinkphp6.x+Workerman入门基础教程

知识技术 2022-04-29 14:46 1494
转载请务必注明: 来源:《建站管家》https://www.df81.com/news/329.html

鉴于好多朋友,根据官方文档苦于无法下手,特别是新手朋友们。刚接触的时候正是因为自己也有这样的困惑,才写下这篇文章,希望能帮助到你们,给到你们学习中的一点小小的动力。
假设你已经会thinkphp6了或者tp5,至少会安装tp和输出hello word了

一、安装thinkphp6(按照tp官网安装即可)

二、安装workerman,这里我们安装tp的扩展:think-worker

composer require topthink/think-worker


三、自定义Workerman服务类目


四、WebSocket示例代码


4-1、view/index/index.html 代码如下 

<!DOCTYPE html>
<html>
<head>
    <title>HTML5</title>
    <meta charset="utf-8" />
    <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
    <script>
        $(function() {
            var socket;
            var readyState = ["connecting", "connected", "closing", "closed"];
            /* 打开连接事件 */
            $("button:eq(0)").click(function() {
                try {
                    /* 连接 */
                    //  socket = new WebSocket("ws://39.96.9.241:6789");
                    socket = new WebSocket("ws://127.0.0.1:2345");
 
                    /* 绑定事件 */
                    socket.onopen = function() {
                        $("#msg").html("连接成功...");
                    };
 
                    socket.onmessage = function(e) {
                        $("#msg").html($("#msg").html() + "<br />" + e.data);
                    };
 
                    socket.onclose = function() {
                        $("#msg").html($("#msg").html() + "<br />关闭连接...");
                    };
                } catch(exception) {
                    $("#msg").html($("#msg").html() + "<br />有错误发生");
                }
            });
 
            /* 发送数据事件 */
            $("button:eq(1)").click(function() {
                /* 检查文本框是否为空 */
                if($("#data").val() == "") {
                    alert("请输入数据!");
                    return;
                }
 
                try {
                    socket.send($("#data").val());
                    $("#msg").html($("#msg").html() + "<br />发送数据:" + $("#data").val());
                } catch (exception) {
                    $("#msg").html($("#msg").html() + "<br />发送数据出错");
                }
 
                /* 清空文本框 */
                $("#data").val("");
            });
 
            /* 断开连接 */
            $("button:eq(2)").click(function() {
                socket.close();
            });
        });
    </script>
</head>
 
<body>
<h1>WebSocket示例</h1>
<input type="text" id="data" />
<button>打开连接</button>
<button>发送数据</button>
<button>关闭连接</button>
<p id="msg"></p>
</body>
</html>


4-2、服务类的内容


<?php
namespace app\index\controller;
use think\facade\Db;
use think\worker\Server;
use Workerman\Lib\Timer;
define('HEARTBEAT_TIME', 20);// 心跳间隔55秒
 
class Worker extends Server
{
    protected $socket = 'http://0.0.0.0:2345';
    public function __construct()
    {
        parent::__construct();
        $this->onMessage();
        // 或者这样调用
        $this->worker->onWorkerStart = function($worker)
        {
            echo "Worker starting...\n";
        };
    }
    /**
     * 收到信息
     * @param $connection
     * @param $data
     */
    public function onMessage()
    {
        $this->worker->onMessage = function($connection, $data)
        {
            dump($data);
            $connection->send($data);
        };
    }
 
 
}


4-3、开启服务


4-4、简单运用

OK,简单示例完成。


点赞 (0)

收藏 (0)

本站部分信息来源网络,如有侵权,请联系QQ:1062129401删除。

上一篇: 《建站管家》二次开发文档

下一篇: svg格式文件转换为png图片的方法

请先登录后,再发表评论 ~ ~
发表评论
发表评论
发表帖子
广告位招租( ¥5 / 天 )
点击咨询
相关帖子

如果要判断文件是否存在,用函数 is_file(),如果要判断目录是否存在,用函数 is_dir()
用宝塔安装TP程序后,网站前台可以访问,后台无法访问,不是程序问题,而是web服务器环境配置问题(PHP配置),出现这种问题,一般是windows主机安装宝塔造成的,linux安装宝塔不会出现此错误
广告位招租( ¥3 / 天 )
点击咨询
广告位招租( ¥2 / 天 )
点击咨询
广告位招租( ¥1 / 天 )
点击咨询
最新帖子

小朋友,你爸爸是谁啊?这很单纯的,就像我们碰到别人会问:你吃过饭了吗?类似;许多人初次相识,经常会问:你是做什么的啊?你做什么,好像决定你收入的高低,你,资产的范围
1、升级框架到ThinkPHP8.0.3【要求PHP8.1+环境,推荐PHP8.1】 2、启用/禁用调试模式等小细节改进
后台点击生成站点地图 一直转圈圈没有反应,
在线客服