⚠️ 此代码仓已归档。新地址请访问 ohos_mqtt。| ⚠️ This repository has been archived. For the new address, please visit ohos_mqtt.
使应用程序能够连接到MQTT代理以发布消息、订阅主题和接收发布的消息。
ohpm install @ohos/mqtt
本项目依赖paho.mqtt.c库和third_party_bounds_checking_function库,通过git submodule
引入,下载代码时需加上--recursive
参数。
git clone --recursive https://gitee.com/openharmony-tpc/ohos_mqtt.git
如需使用sslVersion参数去设置SSL/TLS上下文支持的TLS版本,进入到ohos_Mqtt\src\main\cpp\paho.mqtt.c 目录下,执行 modify.sh 脚本,将本目录下的 patch 文件合入到 paho.mqtt.c 源码中。
import { MqttAsync } from '@ohos/mqtt';
// or
// import { MqttClient } from '@ohos/mqtt';
mqtt使用依赖mqtt broker,请使用云服务或自行搭建,将 emqxPage.ets 文件中的如下参数改成对应的值,才能正常运行demo。
// Set Client Configuration
@State topic: string = '';
@State payload: string = '';
@State url: string = '';
@State clientId: string = '';
@State userName: string = "";
@State password: string = "";
将xts中的domain:port替换成正确的域名与端口,才能正常运行xts.
编译ohos_mqtt源码时如果想要开启ssl功能,需要自行编译openssl,openssl集成到应用hap
1.修改编译之前需要在交叉编译中支持编译x86_64架构,可以参考adpater_architecture.md文档。
2.编译之前需要先修改HPKBUILD文件中openssl的版本号以及清除MAKE环境变量
pkgver=OpenSSL_1_1_1t
//修改为
pkgver=openssl-3.4.0
patchflag=true
//修改为
patchflag=false
prepare() {
if $patchflag
//修改为
prepare() {
unset MAKE #清除MAKE环境变量
if $patchflag
3.下载openssl的3.4.0版本,执行以下命令获取对应的sha512值,替换SHA512SUM文件的内容。
sha512num openssl-openssl-3.4.0.tar.gz
4.在cpp目录下新增thirdparty目录,并将编译生成的库拷贝到该目录下,如下图所示
5.在cpp/paho.mqtt.c/CMakeList.txt中添加如下语句
#开启ssl
add_definitions(-DOPENSSL)
#将三方库加入工程中
target_link_libraries(pahomqttc PRIVATE ${NATIVERENDER_ROOT_PATH}/thirdparty/openssl/${OHOS_ARCH}/lib/libssl.a)
target_link_libraries(pahomqttc PRIVATE ${NATIVERENDER_ROOT_PATH}/thirdparty/openssl/${OHOS_ARCH}/lib/libcrypto.a)
#将三方库的头文件加入工程中
target_include_directories(pahomqttc PRIVATE ${NATIVERENDER_ROOT_PATH}/thirdparty/openssl/${OHOS_ARCH}/include)
new MqttClient(options: MqttAsyncClientOptions): MqttClient
创建mqtt客户端。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttAsyncClientOptions | 是 | 客户端参数 |
返回值:
类型 | 说明 |
---|---|
MqttClient | mqtt客户端,里面包括connect,publish等方法 |
示例:
this.mqttAsyncClient = new MqttClient({
url: "ip:port",
clientId: "e5fatos4jh3l79lndb0bs",
persistenceType: 1,
})
createMqtt(options: MqttAsyncClientOptions): MqttClient
创建mqtt客户端。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttAsyncClientOptions | 是 | 客户端参数 |
返回值:
类型 | 说明 |
---|---|
MqttClient | mqtt客户端,里面包括connect,publish等方法 |
示例:
this.mqttAsyncClient = MqttAsync.createMqtt({
url: "ip:port",
clientId: "e5fatos4jh3l79lndb0bs",
persistenceType: 1,
})
connect(options: MqttConnectOptions, callback: AsyncCallback): void
连接mqtt服务器。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttConnectOptions | 是 | 参考MqttConnectOptions |
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例1:
let options: MqttConnectOptions = {
//set userName and password
userName: "",
password: "",
connectTimeout: 30,
version: 0,
};
this.mqttAsyncClient.connect(options, (err: Error, data: MqttResponse) => {
// to do Something
});
示例2:
连接ssl端口
let options: MqttConnectOptions = {
//set userName and password
userName: "",
password: "",
connectTimeout: 30,
version: 0,
// If connecting to an SSL port, the following parameters need to be configured
sslOptions: {
// true: enable server certificate authentication, false: disable,default is true.
enableServerCertAuth: true,
// Sandbox path for CA certificate
// If enableServerCertAuth is true, a CA certificate needs to be passed
// If enableServerCertAuth is false, a CA certificate does not need to be passed
// trustStore default value is "/etc/ssl/certs/cacert.pem"
trustStore: fileDir + "/ca.crt"
}
};
this.mqttAsyncClient.connect(options, (err: Error, data: MqttResponse) => {
// to do Something
});
connect(options: MqttConnectOptions): Promise
连接mqtt服务器。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttConnectOptions | 是 | 参考MqttConnectOptions |
返回值:
类型 | 说明 |
---|---|
Promise<MqttResponse> | 以Promise形式返回发起连接的结果。 |
示例:
let options: MqttConnectOptions = {
//set userName and password
userName: "",
password: "",
connectTimeout: 30,
version: 0,
};
this.mqttAsyncClient.connect(options).then((data: MqttResponse) => {
console.log("mqtt connect success "+ JSON.stringify(data));
}).catch((err: MqttResponse) => {
console.log("mqtt connect fail"+JSON.stringify(err))
})
try{
let result: MqttResponse = await this.mqttAsyncClient.connect(options)
console.log("mqtt connect success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt connect fail "+ JSON.stringify(err));
}
示例2:
连接ssl端口
let options: MqttConnectOptions = {
//set userName and password
userName: "",
password: "",
connectTimeout: 30,
version: 0,
// If connecting to an SSL port, the following parameters need to be configured
sslOptions: {
// true: enable server certificate authentication, false: disable,default is true.
enableServerCertAuth: true,
// Sandbox path for CA certificate
// If enableServerCertAuth is true, a CA certificate needs to be passed
// If enableServerCertAuth is false, a CA certificate does not need to be passed
trustStore: fileDir + "/ca.crt"
}
};
this.mqttAsyncClient.connect(options).then((data: MqttResponse) => {
console.log("mqtt connect success "+ JSON.stringify(data));
}).catch((err: MqttResponse) => {
console.log("mqtt connect fail"+JSON.stringify(err))
})
try{
let result: MqttResponse = await this.mqttAsyncClient.connect(options)
console.log("mqtt connect success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt connect fail "+ JSON.stringify(err));
}
publish(options: MqttPublishOptions, callback: AsyncCallback): void
发布消息。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttPublishOptions | 是 | 参考MqttPublishOptions |
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例:
let publishOption: MqttPublishOptions = {
topic: "domotopic",
qos: 1,
payload: "haishangdebing",
}
this.mqttAsyncClient.publish(publishOption, (err: Error, data: MqttResponse) => {
// to do Something
});
publish(options: MqttPublishOptions): Promise
发布消息。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttPublishOptions | 是 | 参考MqttPublishOptions |
返回值:
类型 | 说明 |
---|---|
Promise<MqttResponse> | 以Promise形式返回发布的结果。 |
示例:
let publishOption: MqttPublishOptions = {
topic: "domotopic",
qos: 1,
payload: "haishangdebing",
}
this.mqttAsyncClient.publish(publishOption, (data: MqttResponse) => {
console.log("mqtt publish success "+ JSON.stringify(data));
}).catch((err: MqttResponse) => {
console.log("mqtt publish fail "+ JSON.stringify(err));
})
try{
let result: MqttResponse = await this.mqttAsyncClient.publish(publishOption)
console.log("mqtt publish success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt publish fail "+ JSON.stringify(err));
}
subscribe(options: MqttSubscribeOptions, callback: AsyncCallback): void
订阅主题。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions | 是 | 参考MqttSubscribeOptions |
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
this.mqttAsyncClient.subscribe(subscribeOption, (err: Error, data: MqttResponse) => {
// to do Something
});
subscribe(options: MqttSubscribeOptions): Promise
订阅主题。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions | 是 | 参考MqttSubscribeOptions |
返回值:
类型 | 说明 |
---|---|
Promise<MqttResponse> | 以Promise形式返回订阅的结果。 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
this.mqttAsyncClient.subscribe(subscribeOption).then((data: MqttResponse) => {
console.log("mqtt subscribe success "+ JSON.stringify(result));
}).catch((err: MqttResponse) => {
console.log("mqtt subscribe fail "+ JSON.stringify(err));
})
try{
let result: MqttResponse = await this.mqttAsyncClient.subscribe(subscribeOption)
console.log("mqtt subscribe success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt subscribe fail "+ JSON.stringify(err));
}
订阅多个主题
subscribeMany(options: MqttSubscribeOptions[]): Promise
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions[] | 是 | 参考MqttSubscribeOptions |
返回值:
类型 | 说明 |
---|---|
Promise<MqttResponse> | 以Promise形式返回订阅的结果。 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
let subscribeOption1: MqttSubscribeOptions = {
topic: "domotopic1",
qos: 2
}
let subscribeOption2: MqttSubscribeOptions = {
topic: "domotopic2",
qos: 2
}
this.mqttAsyncClient.subscribeMany([subscribeOption, subscribeOption1, subscribeOption2]).then((data: MqttResponse) => {
console.log("mqtt subscribeMany success "+ JSON.stringify(result));
}).catch((err: MqttResponse) => {
console.log("mqtt subscribeMany fail "+ JSON.stringify(err));
})
try{
let result: MqttResponse = await this.mqttAsyncClient.subscribeMany([subscribeOption, subscribeOption1, subscribeOption2])
console.log("mqtt subscribeMany success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt subscribeMany fail "+ JSON.stringify(err));
}
订阅多个主题
subscribeMany(options: MqttSubscribeOptions[], callback: AsyncCallback): void
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions[] | 是 | 参考MqttSubscribeOptions |
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
let subscribeOption1: MqttSubscribeOptions = {
topic: "domotopic1",
qos: 2
}
let subscribeOption2: MqttSubscribeOptions = {
topic: "domotopic2",
qos: 2
}
this.mqttAsyncClient.subscribeMany([subscribeOption, subscribeOption1, subscribeOption2], (err: Error, data: MqttResponse) => {
// to do Something
});
unsubscribe(options: MqttSubscribeOptions, callback: AsyncCallback): void
取消订阅。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions | 是 | 参考MqttSubscribeOptions |
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
this.mqttAsyncClient.unsubscribe(subscribeOption, (err: Error, data: MqttResponse) => {
// to do Something
});
unsubscribe(options: MqttSubscribeOptions): Promise
取消订阅。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions | 是 | 参考MqttSubscribeOptions |
返回值:
类型 | 说明 |
---|---|
Promise<MqttResponse> | 以Promise形式返回取消订阅的结果。 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
this.mqttAsyncClient.unsubscribe(subscribeOption).then((data: MqttResponse) => {
console.log("mqtt unsubscribe success "+ JSON.stringify(result));
}).catch((err: MqttResponse) => {
console.log("mqtt unsubscribe fail "+ JSON.stringify(err));
})
try{
let result: MqttResponse = await this.mqttAsyncClient.unsubscribe(subscribeOption)
console.log("mqtt unsubscribe success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt unsubscribe fail "+ JSON.stringify(err));
}
取消多个主题的订阅
unsubscribeMany(options: MqttSubscribeOptions[]): Promise
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions[] | 是 | 参考MqttSubscribeOptions |
返回值:
类型 | 说明 |
---|---|
Promise<MqttResponse> | 以Promise形式返回取消订阅的结果。 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
let subscribeOption1: MqttSubscribeOptions = {
topic: "domotopic1",
qos: 2
}
let subscribeOption2: MqttSubscribeOptions = {
topic: "domotopic2",
qos: 2
}
this.mqttAsyncClient.unsubscribeMany([subscribeOption, subscribeOption1, subscribeOption2]).then((data: MqttResponse) => {
console.log("mqtt unsubscribeMany success "+ JSON.stringify(result));
}).catch((err: MqttResponse) => {
console.log("mqtt unsubscribeMany fail "+ JSON.stringify(err));
})
try{
let result: MqttResponse = await this.mqttAsyncClient.unsubscribeMany([subscribeOption, subscribeOption1, subscribeOption2])
console.log("mqtt unsubscribeMany success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt unsubscribeMany fail "+ JSON.stringify(err));
}
取消多个主题的订阅
unsubscribeMany(options: MqttSubscribeOptions[], callback: AsyncCallback): void
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
options | MqttSubscribeOptions[] | 是 | 参考MqttSubscribeOptions |
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例:
let subscribeOption: MqttSubscribeOptions = {
topic: "domotopic",
qos: 2
}
let subscribeOption1: MqttSubscribeOptions = {
topic: "domotopic1",
qos: 2
}
let subscribeOption2: MqttSubscribeOptions = {
topic: "domotopic2",
qos: 2
}
this.mqttAsyncClient.unsubscribeMany([subscribeOption, subscribeOption1, subscribeOption2], (err: Error, data: MqttResponse) => {
// to do Something
});
messageArrived(callback: AsyncCallback): void
接收消息,使用此接口后,当订阅的主题有消息发布时,会自动接收到消息。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
callback | AsyncCallback< MqttMessage > | 是 | 回调函数 |
示例:
this.mqttAsyncClient.messageArrived((err: Error, data: MqttMessage) => {
// to do Something
});
disconnect(callback: AsyncCallback): void
断开连接。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例:
this.mqttAsyncClient.disconnect((err: Error, data: MqttResponse) => {
// to do Something
});
disconnect(): Promise
断开连接。
返回值:
类型 | 说明 |
---|---|
Promise<MqttResponse> | 以Promise形式返回断开连接的结果。 |
示例:
this.mqttAsyncClient.disconnect().then((data: MqttResponse) => {
console.log("mqtt disconnect success "+ JSON.stringify(result));;
}).catch((err: MqttResponse) => {
console.log("mqtt disconnect fail "+ JSON.stringify(err));
})
try{
let result: MqttResponse = await this.mqttAsyncClient.disconnect()
console.log("mqtt disconnect success "+ JSON.stringify(result));
}catch(err){
console.log("mqtt disconnect fail "+ JSON.stringify(err));
}
connectLost(callback: AsyncCallback): void
当被动的断开连接后的回调(比如断网),可以在回调中尝试重新连接。
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
callback | AsyncCallback< MqttResponse > | 是 | 回调函数 |
示例:
this.mqttAsyncClient.connectLost((err: Error, data: MqttResponse) => {
// to do Something
});
isConnected(): Promise
是否已连接。
返回值:
类型 | 说明 |
---|---|
Promise | 以Promise形式返回判断是否连接的结果。 |
示例:
this.mqttAsyncClient.isConnected().then((data: boolean) => {
console.log("result: "+data)
});
let result: boolean = await this.mqttAsyncClient.isConnected() //true or false
reconnect(): Promise
重新连接(必须之前连接过)。
返回值:
类型 | 说明 |
---|---|
Promise | 以Promise形式返回重连的的结果。 |
示例:
this.mqttAsyncClient.reconnect().then((data: boolean) => {
console.log('result: ' + data)
});
let result: boolean = await this.mqttAsyncClient.reconnect() //true or false
destroy(): Promise
销毁客户端。
返回值:
类型 | 说明 |
---|---|
Promise | 以Promise形式返回销毁的结果。 |
示例:
this.mqttAsyncClient.destroy().then((data: boolean) => {
console.log('result: ' + data)
});
let result: boolean = await this.mqttAsyncClient.destroy() //true or false
setMqttTrace(level: MQTTASYNC_TRACE_LEVELS): void
设置hilog中跟踪信息的级别。
this.mqttAsyncClient.setMqttTrace(6);
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
level | MQTTASYNC_TRACE_LEVELS | 是 | 消息跟踪级别 |
消息跟踪级别
名称 | 值 |
---|---|
MQTTASYNC_TRACE_MAXIMUM | 1 |
MQTTASYNC_TRACE_MEDIUM | 2 |
MQTTASYNC_TRACE_MINIMUM | 3 |
MQTTASYNC_TRACE_PROTOCOL | 4 |
MQTTASYNC_TRACE_ERROR | 5 |
MQTTASYNC_TRACE_SEVERE | 6 |
MQTTASYNC_TRACE_FATAL | 7 |
创建客户端可选参数的类型和可选范围
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
url | string | 是 | 以null结尾的字符串,指定客户端将连接到的服务器。它采取的形式protocol://host:port.protocol必须是tcp、ssl、ws或wss。对于主机,可以指定IP地址或主机名。例如,tcp://localhost:1883 |
clientId | string | 是 | 客户端连接到服务器时传递给服务器的客户端标识符。它是一个以空结尾的UTF-8编码字符串 |
persistenceType | PersistenceType | 否 | 客户端使用的持久性类型,0=默认值:使用默认(基于文件系统)持久性机制。1=在内存持久性中使用。2=使用特定于应用程序的持久性实现 |
客户端连接服务器可选参数的类型和可选范围
参数名 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
cleanSession | boolean | 否 | true | 这是一个布尔值。设置控制客户端和服务器在连接和断开连接时的行为 |
connectTimeout | number | 否 | 30s | 设置连接超时时间,默认 |
keepAliveInterval | number | 否 | 60s | 保持活动间隔 |
serverURIs | Array | 否 | 客户端连接到的服务器url | |
retryInterval | number | 否 | 0 | 未确认的发布请求的时间间隔 |
sslOptions | number | 否 | 参考sslOptions | |
willOptions | number | 否 | 参考willOptions | |
MQTTVersion | number | 否 | 0 | 设置要在连接上使用的MQTT版本, 0=默认值:从3.1.1开始,如果失败,则返回到3.1,3=仅尝试版本3.1,4=仅尝试3.1.1版本 |
automaticReconnect | boolean | 否 | false | 是否在连接丢失的情况下自动重新连接 |
minRetryInterval | number | 否 | 1s | 以秒为单位的最小重试间隔。每次重试失败时加倍 |
maxRetryInterval | number | 否 | 60s | 以秒为单位的最大重试间隔。重试失败时,加倍在此停止 |
userName | string | 是 | 用户名 | |
password | string | 是 | 密码 |
ssl连接的可选参数的类型的可选的范围。
参数名 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
enableServerCertAuth | boolean | 否 | true | 是否启用服务器证书身份验证 |
verify | boolean | 否 | false | 是否验证主机名 |
caPath | string | 否 | NULL | 如果CApath不为NULL,则它指向包含PEM格式的CA证书的目录 |
trustStore | string | 否 | 系统证书:"/etc/ssl/certs/cacert.pem" | PEM格式的文件,其中包含客户端信任的公共数字证书。它必须在设备中设置本地文件路径,并且必须可以访问该文件。 |
keyStore | string | 否 | NULL | PEM格式的文件,包含客户端的公共证书链。它还可能包括客户端的私钥。它必须在设备中设置本地文件路径,并且必须可以访问该文件 |
privateKey | string | 否 | NULL | 如果未包含在sslKeyStore中,则此设置指向PEM格式的文件,该文件包含客户端的私钥。它必须在设备中设置本地文件路径,并且必须可以访问该文件。 |
privateKeyPassword | string | 否 | NULL | 如果加密,则加载客户端私钥的密码 |
enabledCipherSuites | string | 否 | “ALL” | 客户端将在SSL握手期间呈现给服务器的密码套件列表。如果忽略此设置,其默认值将为“ALL”,即,将考虑所有密码套件,不包括不提供加密的套件 |
sslVersion | MQTT_SSL_VERSION | 否 | 0 | 设置SSL/TLS上下文支持的TLS版本 |
TLS版本
名称 | 值 |
---|---|
MQTT_SSL_VERSION_DEFAULT | 0 |
MQTT_SSL_VERSION_TLS_1_0 | 1 |
MQTT_SSL_VERSION_TLS_1_1 | 2 |
MQTT_SSL_VERSION_TLS_1_2 | 3 |
定义客户机的MQTT“Last Will and Testament”(LWT)设置。如果客户端意外断开与服务器的连接,服务器将代表客户端将LWT消息发布到LWT主题。这允许别的客户端(订阅了LWT主题)知道客户端已断开连接。
参数名 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
topicName | string | 是 | 主题名称 | |
message | string | 是 | 发布的消息 | |
retained | boolean | 否 | false | 是否保留此消息 |
qos | QoS | 否 | 0 | LWT消息的服务质量设置 |
发布消息可选参数类型的可选范围
参数名 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
topic | string | 是 | 主题名称 | |
qos | QoS | 是 | 0 | 消息的服务质量设置 。 |
订阅主题的可选参数类型和可选范围
参数名 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
topic | string | 是 | 主题名称 | |
payload | string | 可选 | 发布的消息 | |
payloadBinary | ArrayBuffer | 可选 | 发布的消息 | |
qos | QoS | 是 | 消息的服务质量设置 | |
retained | boolean | 否 | false | 是否保留此消息 |
dup | boolean | 否 | false | 此消息是否重复,它仅在接收QoS1消息时才有意义 |
msgid | number | 否 | 0 | 消息标识符保留供MQTT客户机和服务器内部使用 |
mqtt接口的返回值类型
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
message | string | 是 | 返回接口调用信息 ,成功或失败 |
code | number | 是 | 如果返回值0,则操作成功。 |
messageArrived接口的返回类型
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
topic | string | 是 | 主题名称 |
payload | string | 可选 | 发布的消息 |
payloadBinary | ArrayBuffer | 可选 | 发布的消息 |
qos | QoS | 是 | 消息的服务质量设置 |
retained | number | 是 | 是否保留此消息 |
dup | number | 是 | 此消息是否重复,它仅在接收QoS1消息时才有意义 |
msgid | number | 是 | 消息标识符保留供MQTT客户机和服务器内部使用 |
在下述版本验证通过:
|----ohos_mqtt
| |---- entry # 示例代码文件夹
| |---- ohos_Mqtt # ohos_Mqtt库文件夹
| |---- cpp # c/c++和napi代码
| |---- mqtt_napi # mqtt的napi逻辑代码
| |---- CMakeLists.txt # 构建脚本
| |---- boundscheck # 子模块third_party_bounds_checking_function
| |---- paho.mqtt.c # 子模块paho.mqtt.c
| |---- ets # 接口声明
| |---- index.ets # 对外接口
| |---- README.md # 安装使用方法
| |---- README_zh.md # 安装使用方法
使用过程中发现任何问题都可以提 Issue 给组件,当然,也非常欢迎给发 PR共建 。
本项目基于 Eclipse Public License - v 2.0 ,请自由地享受和参与开源。
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。