lambq / mqtt
一个简单的Laravel库,用于连接/发布/订阅MQTT代理
0.0.3
2024-06-06 22:48 UTC
Requires
- php: ^7.4|^8.0
- hhxsv5/laravel-s: ^3.7
- simps/mqtt: ^1.4
Requires (Dev)
- laravel/framework: ^6.0.0|^7.0.0|^8.0.0|^9.0.0|^10.0.0|^11.0.0
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