微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

一文快速了解PHP项目中怎么使用MQTT

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 客户端库如下:

项目初始化

确认 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

1.png

总结

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

原文链接:https://www.emqx.com/zh/blog/how-to-use-mqtt-in-PHP

作者:EMQ

推荐学习:《PHP教程

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐