workerman / mqtt
Installs: 45 178
Dependents: 14
Suggesters: 0
Security: 0
Stars: 216
Watchers: 12
Forks: 48
Open Issues: 4
pkg:composer/workerman/mqtt
Requires
- php: ^8.0
- workerman/workerman: ^5.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- revolt/event-loop: ^1.0
Suggests
- ext-event: For better performance.
README
Asynchronous MQTT client for PHP based on workerman.
Installation
composer require workerman/mqtt
文档
support
- MQTT
- MQTT 5
- MQTT over websocket
Example
subscribe.php
<?php require __DIR__ . '/vendor/autoload.php'; use Workerman\Worker; $worker = new Worker(); $worker->onWorkerStart = function(){ $mqtt = new Workerman\Mqtt\Client('mqtt://test.mosquitto.org:1883'); $mqtt->onConnect = function($mqtt) { $mqtt->subscribe('test'); }; $mqtt->onMessage = function($topic, $content){ var_dump($topic, $content); }; $mqtt->connect(); }; Worker::runAll();
Run with command php subscribe.php start
publish.php
<?php require __DIR__ . '/vendor/autoload.php'; use Workerman\Worker; $worker = new Worker(); $worker->onWorkerStart = function(){ $mqtt = new Workerman\Mqtt\Client('mqtt://test.mosquitto.org:1883'); $mqtt->onConnect = function($mqtt) { $mqtt->publish('test', 'hello workerman mqtt'); }; $mqtt->connect(); }; Worker::runAll();
Run with command php publish.php start
API
Client::__construct()Client::connect()Client::publish()Client::subscribe()Client::unsubscribe()Client::disconnect()Client::close()callback onConnectcallback onMessagecallback onErrorcallback onClose
__construct (string $address, [array $options])
Create an instance by $address and $options.
-
$addresscan be on the following protocols: 'mqtt', 'mqtts', 'mqtt://test.mosquitto.org:1883'. -
$optionsis the client connection options. Defaults:keepalive:50seconds, set to0to disableclient_id: client id, defaultworkerman-mqtt-client-{$mt_rand}protocol_name:'MQTT'or 'MQIsdp'protocol_level:'MQTT'is4and 'MQIsdp' is3clean_session:true, set to false to receive QoS 1 and 2 messages while offlinereconnect_period:1second, interval between two reconnectionsconnect_timeout:30senconds, time to wait before a CONNACK is receivedusername: the username required by your broker, if anypassword: the password required by your broker, if anywill: a message that will sent by the broker automatically when the client disconnect badly. The format is:topic: the topic to publishcontent: the message to publishqos: the QoSretain: the retain flag
resubscribe: if connection is broken and reconnects, subscribed topics are automatically subscribed again (defaulttrue)bindtodefault '', used to specify the IP address that PHP will use to access the networkssldefaultfalse, it can be settrueorssl contextsee http://php.net/manual/en/context.ssl.phpdebugdefaultfalse, settrueto show debug info
connect()
Connect to broker specified by the given $address and $options in __construct($address, $options).
publish(String $topic, String $content, [array $options], [callable $callback], [array $properties])
Publish a message to a topic
$topicis the topic to publish to,String$messageis the message to publish,String$optionsis the options to publish with, including:qosQoS level,Number, default0retainretain flag,Boolean, defaultfalsedupmark as duplicate flag,Boolean, defaultfalse
$callback-function (\Exception $exception), fired when the QoS handling completes, or at the next tick if QoS 0. No error occurs then$exceptionwill be null.$properties-arrayMQTT5 user properties
subscribe(mixed $topic, [array $options], [callable $callback], [array $properties])
Subscribe to a topic or topics
$topicis aStringtopic or anArraywhich has as keys the topic name and as value the QoS likearray('test1'=> 0, 'test2'=> 1)to subscribe.$optionsis the options to subscribe with, including:qosqos subscription level, default 0
$callback-function (\Exception $exception, array $granted)callback fired on suback where:exceptiona subscription error or an error that occurs when client is disconnectinggrantedis an array ofarray('topic' => 'qos', 'topic' => 'qos')where:topicis a subscribed to topicqosis the granted qos level on it
$properties-arrayMQTT5 user properties
unsubscribe(mixed $topic, [callable $callback], [array $properties])
Unsubscribe from a topic or topics
$topicis aStringtopic or an array of topics to unsubscribe from$callback-function (\Exception $e), fired on unsuback. No error occurs then$exceptionwill be null..$properties-arrayMQTT5 user properties
disconnect()
Send DISCONNECT package to broker and close the client.
close()
Close the client without DISCONNECT package.
callback onConnect(Client $mqtt)
Emitted on successful connection (CONNACK package received).
callback onMessage(String $topic, String $content, Client $mqtt, array $properties)
function (topic, message, client, properties) {}
Emitted when the client receives a publish packet
$topictopic of the received packet$contentpayload of the received packet$mqttClient instance.$propertiesarrayMQTT5 user properties
callback onError(\Exception $exception)
Emitted when something wrong for example the client cannot connect broker.
callback onClose()
Emitted when connection closed.
License
MIT