最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 如何在 PHP 项目中使用 MQTT

    正文概述 转载于:掘金(EMQX83443)   2021-07-31   573

    php 是一种被广泛应用的开放源代码的多用途脚本语言,它可嵌入到 HTML 中,尤其适合 Web 开发。

    本文主要介绍如何在 PHP 项目中使用 php-mqtt/client 客户端库 ,实现 MQTT 客户端与 MQTT 服务器的连接、订阅、取消订阅、收发消息等功能。

    MQTT 客户端库选择

    本文选择了 composer 上下载量最高的 php-mqtt/client 这个客户端库,更多 PHP-MQTT 客户端库可以在 Packagist - Search MQTT 中查看。

    有关 php-mqtt/client 更多使用文档请参阅 Packagist php-mqtt/client。

    MQTT 通信属于 HTTP 体系之外的网络通信场景,由于 PHP 特性限制,使用 PHP 体系中的 Swoole/Workerman 等专为网络通信打造的拓展可以带来更好的体验,其使用本文不再赘述,相关的 MQTT 客户端库如下:

    • workerman/mqtt:Asynchronous MQTT client for PHP based on workerman.
    • simps/mqtt:MQTT Protocol Analysis and Coroutine Client for PHP.

    项目初始化

    确认 PHP 版本

    本项目使用 7.4.21 进行开发测试,读者可用如下命令确认 PHP 的版本。

    php --version
    
    PHP 7.4.21 (cli) (built: Jul 12 2021 11:52:30) ( NTS )
    Copyright (c) The PHP Group
    Zend Engine v3.4.0, Copyright (c) Zend Technologies
        with Zend OPcache v7.4.21, Copyright (c), by Zend Technologies
    

    使用 Composer 安装 php-mqtt/client 客户端

    Composer 是 PHP 的一个依赖管理工具,它能管理你的 PHP 项目所需要的所有依赖关系。

    composer require php-mqtt/client
    

    PHP MQTT 使用

    连接 MQTT 服务器

    本文将使用 EMQ X 提供的 免费公共 MQTT 服务器,该服务基于 EMQ X 的 MQTT 物联网云平台 创建。服务器接入信息如下:

    • Broker: broker-cn.emqx.io
    • TCP Port: 1883
    • SSL/TLS Port: 8883

    导入 composer autoload 文件和 php-mqtt/client

    require('vendor/autoload.php');
    
    use \PhpMqtt\Client\MqttClient;
    

    设置 MQTT Broker 连接参数

    设置 MQTT Broker 连接地址,端口以及 topic,同时我们调用 PHP rand 函数随机生成 MQTT 客户端 id。

    $server   = 'broker-cn.emqx.io';
    $port     = 1883;
    $clientId = rand(5, 15);
    $username = 'emqx_user';
    $password = null;
    $clean_session = false;
    

    编写 MQTT 连接函数

    使用上述的参数进行连接,通过 ConnectionSettings 设置连接参数,比如

    $connectionSettings  = new ConnectionSettings();
    $connectionSettings
      ->setUsername($username)
      ->setPassword(null)
      ->setKeepAliveInterval(60)
      // Last Will 设置
      ->setLastWillTopic('emqx/test/last-will')
      ->setLastWillMessage('client disconnect')
      ->setLastWillQualityOfService(1);
    

    订阅消息

    编写代码订阅 emqx/test 主题,并为该订阅配置回调函数以处理接收到的消息,此处我们将订阅得到的主题和消息打印出来:

    // 订阅
    $mqtt->subscribe('emqx/test', function ($topic, $message) {
        printf("Received message on topic [%s]: %s\n", $topic, $message);
    }, 0);
    

    发布消息

    构造一个 payload,调用 publish 函数向 emqx/test 主题发布消息,发布完成之后客户端需要进入轮询状态,处理传入的消息和重发队列:

    for ($i = 0; $i< 10; $i++) {
      $payload = array(
        'protocol' => 'tcp',
        'date' => date('Y-m-d H:i:s'),
        'url' => 'https://github.com/emqx/MQTT-Client-Examples'
      );
      $mqtt->publish(
        // topic
        'emqx/test',
        // payload
        json_encode($payload),
        // qos
        0,
        // retain
        true
      );
      printf("msg $i send\n");
      sleep(1);
    }
    
    // 客户端轮询以处理传入消息和重发队列
    $mqtt->loop(true);
    

    完整代码

    服务器连接、消息发布与接收代码。

    <?php
    
    require('vendor/autoload.php');
    
    use \PhpMqtt\Client\MqttClient;
    use \PhpMqtt\Client\ConnectionSettings;
    
    $server   = 'broker.emqx.io';
    $port     = 1883;
    $clientId = rand(5, 15);
    $username = 'emqx_user';
    $password = null;
    $clean_session = false;
    
    $connectionSettings  = new ConnectionSettings();
    $connectionSettings
      ->setUsername($username)
      ->setPassword(null)
      ->setKeepAliveInterval(60)
      // Last Will 设置
      ->setLastWillTopic('emqx/test/last-will')
      ->setLastWillMessage('client disconnect')
      ->setLastWillQualityOfService(1);
    
    
    $mqtt = new MqttClient($server, $port, $clientId);
    
    $mqtt->connect($connectionSettings, $clean_session);
    printf("client connected\n");
    
    $mqtt->subscribe('emqx/test', function ($topic, $message) {
        printf("Received message on topic [%s]: %s\n", $topic, $message);
    }, 0);
    
    for ($i = 0; $i< 10; $i++) {
      $payload = array(
        'protocol' => 'tcp',
        'date' => date('Y-m-d H:i:s'),
        'url' => 'https://github.com/emqx/MQTT-Client-Examples'
      );
      $mqtt->publish(
        // topic
        'emqx/test',
        // payload
        json_encode($payload),
        // qos
        0,
        // retain
        true
      );
      printf("msg $i send\n");
      sleep(1);
    }
    
    $mqtt->loop(true);
    
    

    测试

    运行 MQTT 消息发布代码,我们将看到客户端已经成功连接,且消息已经逐条发布并接收成功:

    php pubsub_tcp.php
    

    如何在 PHP 项目中使用 MQTT

    总结

    至此,我们完成了使用 php-mqtt/client 客户端连接到公共 MQTT 服务器,并实现了测试客户端与 MQTT 服务器的连接、消息发布和订阅。


    起源地下载网 » 如何在 PHP 项目中使用 MQTT

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元