IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> thinkphp6+workerman 小demo -> 正文阅读

[PHP知识库]thinkphp6+workerman 小demo

正常安装

composer require topthink/think-worker`

如果出现异常 报错

?在项目根目录下面的composer.json 文件中设置

"topthink/think-worker": "^3.0",

之后?

composer install 

如果还出现异常 忽略版本更新

composer install --ignore-platform-reqs 

安装成功后

在项目路径下的cofing 文件下找到?config/worker_server.php

只需要动这一个文件

'protocol'       => 'websocket', // 协议 支持 tcp udp unix http websocket text
'host'           => '0.0.0.0', // 监听地址
'port'           => 2346, // 监听端口
'socket'         => '', // 完整监听地址
'context'        => [], // socket 上下文选项
'worker_class'   => 'app\work\Push', // 自定义Workerman服务类名 支持数组定义多个服务

只需要修改worker_class 更改为我们书写的文件绝对路径但是不要后缀 也可以写数组的形式

worker实现 `app/work/Push.php`

只是简单的例子练习

代码如下:

<?php
namespace app\work;
use think\worker\Server;
use Workerman\Lib\Timer;
use think\facade\Db;
class Push extends Server
{
      protected $socket = 'http://0.0.0.0:2346';   //端口自行修改

 
    protected static $heartbeat_time    =   55;
 
    public function onWorkerStart($worker){
        
        //查看是否有新的充值或提现订单,有就推送给所有用户
        Timer::add(3, function()use($worker){
 
            $time_now   =   time();
            $hasNewDepositOrder   =   Db::name('deposit_order')->where('is_push',0)->order('id desc')->count('id');
  
 
            if($hasNewDepositOrder){
                $depositOrderInfo   =   Db::name('deposit_order')->where('is_push',0)->order('id desc')->find();
               
                $data   =   ['money'=>$depositOrderInfo['pay_amount'],'type'=>'deposit'];
                foreach($worker->connections as $connection) {
                    if(empty($connection->lastMessageTime)){
                        $connection->lastMessageTime =   $time_now;
                    }
 
                    if($time_now-$connection->lastMessageTime > self::$heartbeat_time){
                        $connection->close();
                    }
 
                    $connection->send(json_encode($data));
                }
 
               Db::name('deposit_order')->where('id',$depositOrderInfo['id'])->save(['is_push'=>1]);
            }else{
                foreach($worker->connections as $connection) {
                    if(empty($connection->lastMessageTime)){
                        $connection->lastMessageTime = $time_now;
                        continue;
                    }
 
                    if($time_now-$connection->lastMessageTime > self::$heartbeat_time){      //连接超时
                        $connection->close();
                    }
                }
            }
        });
    }
}

启动 每次修改 文件后 最好是从新启动一下服务

php think worker:server start 开启
php think worker:server stop  结束
php think worker:server status  查看状态

?js代码: 随便搞一个静态页面就可以

<script>
            let ws = new WebSocket("ws://换成自己的服务器的IP:2346")
             
            ws.onopen = function() {  //绑定连接事件
                console.log("连接成功");
                //每30秒发送一次心跳
                setInterval(function(){
                    ws.send('123');
                    console.log('发送心跳...');
                },30000)
            };
            ws.onmessage = function (s){
                console.log(s);
            }
            ws.onclose = function(evt) { //绑定关闭或断开连接事件
              console.log("连接已关闭");
            };
        </script>

因为上面是根据数据库的信息插入来进行判断了 所以我们通过结构去表中增加数据在前台的 onmessage 中就可以打印出来数据展示

直接通过数据库的新增数据,就可以把对应的信息展示出来 具体逻辑就是push.php中写的数据库展示逻辑

sql 随便搞的 只是为了能够实现 当数据库添加 能够把数据交互到前台

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for cm_deposit_order
-- ----------------------------
DROP TABLE IF EXISTS `cm_deposit_order`;
CREATE TABLE `cm_deposit_order`  (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '123',
  `is_push` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '0',
  `order_status` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '0',
  `pay_amount` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '2',
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL,
  `create_time` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 27 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Compact;

SET FOREIGN_KEY_CHECKS = 1;

转载地址 整理

https://blog.csdn.net/weixin_39378555/article/details/119057485

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2022-03-31 23:44:14  更:2022-03-31 23:44:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/18 14:40:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码