iisustudio / laravel-mqtt
一个简单的 Laravel 库,用于连接/发布/订阅 MQTT 代理
v2.0.10
2021-11-29 10:52 UTC
Requires
- php: ^7.0 || ^7.1 || ^7.2 || ^7.3 || ^7.4 || ^8.0
Requires (Dev)
- laravel/framework: ^5.5 || ^6.0 || ^7.0 || ^8.0
This package is auto-updated.
Last update: 2024-09-29 06:02:23 UTC
README
一个简单的 Laravel 库,用于连接/发布/订阅 MQTT 代理
例如,请参阅此 仓库
安装
composer require salmanzafar/laravel-mqtt
功能
- 用户名和密码认证
- 客户端证书认证
- 端到端加密的证书保护
- 启用调试模式以方便调试
- 现在您也可以设置您选择的 Client_id,如果您不想使用,只需不使用或将其设置为 null
- 直接从配置文件设置 QOS 标志
- 直接从配置文件设置 Retain 标志
- 添加辅助函数以使开发更简单
启用包(可选)
此包实现了 Laravel 自动发现功能。安装后,自动为 laravel >= 5.5 添加了包提供者和外观。
如果使用 laravel 版本 < 5.5,则需要此步骤
要显式声明提供者和/或别名,请将服务提供者添加到您的 config/app.php
'providers' => [
Salman\Mqtt\MqttServiceProvider::class,
];
然后,将别名添加到您的 config/app.php
'aliases' => [
'Mqtt' => \Salman\Mqtt\Facades\Mqtt::class,
];
配置
发布配置文件
php artisan vendor:publish --provider="Salman\Mqtt\MqttServiceProvider"
Config/mqtt.php
'host' => env('mqtt_host','127.0.0.1'),
'pawd' => env('mqtt_pawd',''),
'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 Salman\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 Salman\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);
}