亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

PHP使用WebSocket主動推送【微信小程序接收】

標簽:
PHP

webp

WebSocket.jpeg

Websocket是一种服务端和客户端可以持久连接的通信协议,我们可以利用WebSocket的特性实现服务器主动向客户端推送消息的功能。

这里我们用TP5.1框架结合Workerman来做演示

首先用Composer下载TP5.1框架

composer create-project topthink/think=5.1.* tp5  --prefer-dist

下载完成后再在项目目录下通过  composer  引入  workerman

composer require topthink/think-worker

等完成后就可以在 vendor 目录里看到  workerman

注意:本人环境CentOS7,TP5.1框架,PHP版本5.6.0

然后在项目的根目录下新建一个  start.php 文件,用于启动WebSocket服务。

<?phpuse Workerman\Worker;require_once __DIR__ . '/vendor/workerman/workerman/Autoloader.php';// 创建一个Worker监听2345端口,使用websocket协议通讯$http_worker = new Worker("websocket://0.0.0.0:2345");// 这里进程数必须设置为1$http_worker->count = 1;// 接收到浏览器发送的数据时广播给所有用户$http_worker->onMessage = function($connection, $data)use($http_worker){    // 向每一个用户推送消息
    foreach($http_worker->connections as $connection)
    {        //验证管理端秘钥
        $text = explode("KEY:", $data);        if($text[1]=='gi4lXpAOw6ddtFg'){
          $connection->send($text[0]);
        }
    }
};

Worker::runAll();

在根目录下打开命令行工具以daemon(守护进程)方式启动

php start.php start -d


下面是管理端广播消息页面的一张截图


webp

WX20180821-144140.png

管理端js代码如下

<script>
  var ws = new WebSocket("ws://47.94.222.65:2345");
  ws.onopen = function(evt) {    console.log("连接成功");
  };
  $('#send').click(function(){     var text = $('#text').val() + 'KEY:gi4lXpAOw6ddtFg';
     ws.send(text);
  });</script>

微信小程序端接收推送演示


webp

WX20180821-155230.png

微信小程序端代码

wx.connectSocket({   url: 'ws://47.94.222.65:2345'})
wx.onSocketOpen(function (res) {   console.log('WebSocket连接已打开!')
})
wx.onSocketMessage(function (res) {   console.log('收到服务器内容:' + res.data)
})



作者:IT青年
链接:https://www.jianshu.com/p/67c320d19814


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 1
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消