lambq / mqtt

一个简单的Laravel库,用于连接/发布/订阅MQTT代理

维护者

详细信息

gitee.com/cbter/mqtt

0.0.3 2024-06-06 22:48 UTC

This package is auto-updated.

Last update: 2024-09-06 23:26:01 UTC


README

一个简单的Laravel库,用于连接/发布/订阅MQTT代理

安装

$ composer require lambq/mqtt

功能

  • 用户名和密码认证
  • 客户端证书认证
  • 证书保护,实现端到端加密
  • 启用调试模式,以便更容易进行调试
  • 现在您可以设置您选择的Client_id,如果您不想使用,只需简单地不使用或设置为null即可
  • 直接从配置文件设置QOS标志
  • 直接从配置文件设置Retain标志
  • 添加辅助函数,使开发更轻松

启用包(可选)

此包实现了Laravel自动发现功能。安装后,自动为laravel >= 5.5添加了包提供者和外观。

如果使用laravel版本 < 5.5,则此步骤是必需的

要显式声明提供者和/或别名,请将服务提供者添加到您的config/app.php中

'providers' => [
    Lambq\Mqtt\MqttServiceProvider::class,
];

然后将别名添加到您的config/app.php中

'aliases' => [
    'Mqtt' => \Lambq\Mqtt\Facades\Mqtt::class,
];

配置

发布配置文件

php artisan vendor:publish --provider="Lambq\Mqtt\MqttServiceProvider"

Config/mqtt.php

    'host'      => env('mqtt_host','127.0.0.1'),
    'password'  => env('mqtt_password',''),
    'username'  => env('mqtt_username',''),
    'certfile'  => env('mqtt_cert_file',''),
    'localcert' => env('mqtt_local_cert', ''),
    'localpk'   => env('mqtt_local_pk', ''),
    'port'      => env('mqtt_port','1883'),
    'debug'     => env('mqtt_debug',false) //Optional Parameter to enable debugging set it to True
    'qos'       => env('mqtt_qos', 0), // set quality of service here
    'retain'    => env('mqtt_retain', 0) // it should be 0 or 1 Whether the message should be retained.- Retain Flag

发布主题

use Lambq\Mqtt\MqttClass\Mqtt;

public function SendMsgViaMqtt($topic, $message)
{
        $mqtt = new Mqtt();
        $client_id = Auth::user()->id;
        $output = $mqtt->ConnectAndPublish($topic, $message, $client_id);

        if ($output === true)
        {
            return "published";
        }
        
        return "Failed";
}

使用外观发布主题

use Mqtt;

public function SendMsgViaMqtt($topic, $message)
{
        $client_id = Auth::user()->id;
        
        $output = Mqtt::ConnectAndPublish($topic, $message, $client_id);

        if ($output === true)
        {
            return "published";
        }

        return "Failed";
}

订阅主题

use Lambq\Mqtt\MqttClass\Mqtt;

public function SubscribetoTopic($topic)
    {
        $mqtt = new Mqtt();
        $client_id = Auth::user()->id;
        $mqtt->ConnectAndSubscribe($topic, function($topic, $msg){
            echo "Msg Received: \n";
            echo "Topic: {$topic}\n\n";
            echo "\t$msg\n\n";
        }, $client_id);


    }

使用外观订阅主题

use Mqtt;

public function SubscribetoTopic($topic)
    {
       //You can also subscribe to multiple topics using the same function $topic can be array of topics e.g ['topic1', 'topic2']

       Mqtt::ConnectAndSubscribe($topic, function($topic, $msg){
            echo "Msg Received: \n";
            echo "Topic: {$topic}\n\n";
            echo "\t$msg\n\n";
        },$client_id);


    }

使用辅助方法发布主题


public function SendMsgViaMqtt($topic, $message)
{
        $client_id = Auth::user()->id;
        
        $output = connectToPublish($topic, $message, $client_id);

        if ($output === true)
        {
            return "published";
        }

        return "Failed";
}

使用辅助方法订阅主题

//You can also subscribe to multiple topics using the same function $topic can be array of topics e.g ['topic1', 'topic2']
public function SubscribetoTopic($topic)
{
  return connectToSubscribe($topic,$client_id);
}

友情提示

PHP FPM环境适合同步阻塞模式类型2

如果您想使用协作程序客户端,请使用https://github.com/hhxsv5/laravel-s加速您的Laravel项目类型1