百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

yii2框架融合workman 消息推送socketIO 插件

ccwgpt 2024-09-15 15:10 20 浏览 0 评论

需求

  目前项目需要做了实时推送功能,使用websocket 及时向多个用户端推送信息提醒功能

解决办法

  考虑开发成本和维护便捷,考虑使用成熟框架workerman的官方socketIo插件功能

解决步奏

1、安装插件

使用composer 下载 workerman的phpsocket.io插件

   命令:

  
  composer require workerman/phpsocket.io

2、.env(yii2框架根目录)配置文件 添加

// 监听 内网ip 
INNER_NET=10.46.224.26
// 内网端口1
SOCKET_PORT1=9504
// 内网端口2
SOCKET_PORT2=9506

3、服务命令

  在yii2框架的 console 文件夹下controller里创建控制器WeChatController控制器 创建 start-up 方法,重新定义websocket开启方法 开启socket服务

public function actionStartup(array $name = []){
        global $argv;
        // var_export($argv) ; die();
        $action_s = isset($argv[2]) ? $argv[2] : '' ;
        $argv[0] = $argv[1];
        $argv[1] = $action_s;
        if (isset($argv[3]) &&$argv[3] && in_array($argv[3],$this->use_mode) ) {
            switch ($action_s){
                case 'start':
                case 'status':
                    if($argv[3] == self::DAEMON){
                        $argv[2] = '-'.$argv[3] ;
                    }
                    break ;
                case 'restart':
                    if($argv[3] == self::DAEMON || $argv[3]==self::GRACEFULLY){
                        $argv[2] = '-'.$argv[3] ;
                    }
                    break ;
                case 'reload':
                case 'stop':
                    if($argv[3]==self::GRACEFULLY){
                        $argv[2] = '-'.$argv[3] ;
                    }
                    break ;
            }
        }
        $ip = getenv('INNER_NET') ;
        $io = new SocketIO(getenv("SOCKET_PORT2"),[],$ip);

        $service = (new WorkmanSocketService()) ;
        $service->listenInit($io);
        //var_dump($io) ;
        // 当有客户端连接时打印一行文字
        Worker::runAll();
    }

  开启服务命令

启动命令 
    以debug(调试)方式启动
    php ./yii websocket/startup start
    以daemon(守护进程)方式启动 (注意不是-d 是小写字符d 和官方文档有点差异)
    php ./yii websocket/startup start  d
    停止
    php ./yii websocket/startup  stop
    重启
    php ./yii websocket/startup restart
    平滑重启
    php ./yii websocket/startup reload
    查看状态
    php ./yii websocket/startup status
    查看连接状态(需要Workerman版本>=3.5.0)
    php ./yii websocket/startup connections

4、支持SSL(https wss)

  SSL支持有两种方法,workerman原生和nginx代理

  workerman原生支持
  SSL 要求workerman>=3.3.7 phpsocket.io>=1.1.1

<?php
require_once __DIR__ . '/vendor/autoload.php';
use Workerman\Worker;
use PHPSocketIO\SocketIO;

// 传入ssl选项,包含证书的路径
$context = array(
    'ssl' => array(
        'local_cert'  => '/your/path/of/server.pem',
        'local_pk'    => '/your/path/of/server.key',
        'verify_peer' => false,
    )
);
$io = new SocketIO(2120, $context);

$io->on('connection', function($socket)use($io){
  echo "new connection coming\n";
});

Worker::runAll();

注意:

  1、证书是要验证域名的,所以客户端链接时要指定域名才能顺利地建立链接。
  2、客户端连接时不能再用http方式,要改成https类似下面这样。

<script>
var socket = io('https://yoursite.com:2120');
//.....
</script>

nginx代理SSL

前提条件及准备工作:
1、已经安装nginx,版本不低于1.3
2、假设phpsocket.io监听的是2120端口
3、已经申请了证书(pem/crt文件及key文件)放在了/etc/nginx/conf.d/ssl下
4、打算利用nginx开启443端口对外提供ssl代理服务(端口可以根据需要修改)
nginx配置类似如下:

server {
  listen 443;

  ssl on;
  ssl_certificate /etc/ssl/server.pem;
  ssl_certificate_key /etc/ssl/server.key;
  ssl_session_timeout 5m;
  ssl_session_cache shared:SSL:50m;
  ssl_protocols SSLv3 SSLv2 TLSv1 TLSv1.1 TLSv1.2;
  ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;

  location /socket.io
  {
    proxy_pass http://127.0.0.1:2120;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "Upgrade";
    proxy_set_header X-Real-IP $remote_addr;
  }

  # location / {} 站点的其它配置...
}

注意:

  1、证书是要验证域名的,所以客户端链接时要指定域名才能顺利地建立链接。
  2、客户端连接时不能再用http方式,要改成https类似下面这样。

<script>
var socket = io('https://yoursite.com');
//.....
</script>

5、业务逻辑

  首先通过php ./yii websocket/startup 开启socketIo 服务。
 如图:


就是成功开启了一个socketIo 服务 ,
在socketIo 连接初始化是创建 监听http 服务 , 后续我可以通过 这个http 实现服务器端向客户端推送信息:

服务器推送代码接口如下: 通过curl post 推送接口 经过workerman 转发给每个用户客户端

public function sendContent($content,$dataSetId = 0){
    if(isSsl()){
        $push_api_url = "https://".getenv("INNER_NET").":".getenv("SOCKET_PORT1")."/";
    } else {
        $push_api_url = "http://".getenv("INNER_NET").":".getenv("SOCKET_PORT1")."/";
    }
    $post_data = array(
        "type" => self::SocketMessage,
        "content" => $content,
        "dataSetId" => $dataSetId,
    );
    $ch = curl_init();
    curl_setopt( $ch, CURLOPT_URL, $push_api_url );
    curl_setopt( $ch, CURLOPT_POST, 1 );
    curl_setopt( $ch, CURLOPT_HEADER, 0 );
    curl_setopt( $ch, CURLOPT_RETURNTRANSFER, 1 );
    curl_setopt( $ch, CURLOPT_POSTFIELDS, $post_data );
    curl_setopt($ch, CURLOPT_HTTPHEADER, array("Expect:"));
    $return = curl_exec( $ch );
    $error = curl_error($ch) ;
    curl_close($ch);
    var_dump($error);
    echo $return ;
    return $return ;
}

相关推荐

NestJS入门教程系列一

介绍Nest(NestJS)是用于构建高效,可扩展的Node.js服务器端应用程序的框架。它使用渐进式JavaScript,内置并完全支持TypeScript(但开发人员仍然能够使用JavaScrip...

【推荐】一个网盘资源搜索与转存工具,支持移动端与PC端!

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍CloudSaver是一个基于Vue3和Express的网盘资源搜索与转存开源实用工具。它支持...

Appium原理精讲

目前使用Appium新版本和旧版本的企业数目都很多,而两个版本的安装过程和api的使用又有较大的区别。但是无论表面上的东东如何变化,内部原理都是一样的。在这里我给大家介绍一下appium的核心,增进大...

Kubernetes最小部署单元Pod

一、Kubernetes与Pod简介在当今云计算和容器化技术盛行的时代,Kubernetes已然成为容器编排领域的中流砥柱。它是一个开源的容器编排平台,由Google基于其内部使用的Bo...

最常用的四种跨域解决方案

前置知识什么是跨域?浏览器发送的请求地址(URL)与所在页面的地址不同(端口/协议/域名其一不同)。简言之,浏览器发出的请求url,与其所在页面的url不一样。此时,同源策略会让浏览器拒收服务器...

Bolt.New —— 全栈AI Web自动编程

Bolt.New是由StackBlitz公司推出的,全栈AI工具,代码编辑、运行、部署,通通一站式搞定。它使用WebContainers技术,无需任何本地安装或配置,在浏览器中,就可以运行完整的No...

Nodejs Express新手教程&amp;高手进阶

NodejsExpress新手教程&高手进阶Express是一个NodeJS平台的框架,主要用于构于Web服务器项目。本文将通过示例介绍适合新手入门的Express基础使用,以及高手进阶知识,如:c...

Express.js 创建Node.js Web应用

Express.js是一个基于Node.js的Web应用框架,框架的设计目的是构建应用的架构和简化应用的开发。框架会解决一些通用的问题,在Express.js中,Express框架会处理如:中间件、代...

JavaScript 的 Express.js 功能及应用场景详解

Express.js是一个基于Node.js的轻量级Web应用框架,主要用于快速构建服务器端应用和API。它的核心功能包括以下关键点:1.路由管理URL路径与HTTP方法映射:通过...

nodejs的express4文件下载

在nodejs的express框架中,下载变得非常简单,就一个方法,res.download()首先express命令行生成项目基本框架:不会的看这里:http://blog.csdn.net/zz...

Express 系列:快速生成一个项目

系列预告本系列将以一个项目入手结合相关技术细节来带领大家一起学习Express这个基于Node.js的后端框架。本文首先将介绍:如何快速的生成一个具有一定结构的Express项目。Express项目结...

nodejs的express自动生成项目框架

nodejs版本为:4.X,express版本为4.X1.全局安装2个模块express、express-generator在命令行输入:npminstall-gexpressnpminsta...

express开发(一)简介与搭建

上周末去了趟上海书城,不愧是上海数得上号的书城,流行的科技书应有尽有,话不多说直接上图。最经典的C语言O(∩_∩)O最流行的java(づ ̄3 ̄)づ超酷的R语言/(ㄒoㄒ)/~~然而,身为一个坚定的前...

Vue+Echarts可视化大屏系统后端框架搭建(附代码)

各位同学,大家好。上节课,前面我们讲解了Vue+Echarts前端部分的设计方法。这节课程,我们开始讲解使用Express进行后端设计的方法。01项目相关理论介绍什么是expressExpress是...

Shopify电商API接口开发

Shopify电商API接口开发上线流程主要包括以下步骤。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎洽谈合作。前期准备-注册Shopify账号:在Shopify官网注册,用于后续开发测试...

取消回复欢迎 发表评论: