Link Kit C-SDK
4.1.0
|
MQTT模块头文件, 提供用MQTT协议连接阿里云物联网平台的能力 更多...
类 | |
struct | aiot_mqtt_recv_t |
struct | aiot_mqtt_event_t |
MQTT内部事件 更多... | |
struct | aiot_mqtt_topic_map_t |
使用 aiot_mqtt_setopt 配置 AIOT_MQTTOPT_APPEND_TOPIC_MAP 时的数据 更多... | |
struct | will_message_t |
遗嘱消息 更多... | |
struct | sub_options_t |
订阅选项 更多... | |
宏定义 | |
#define | USER_PROPERTY_MAX (20) |
类型定义 | |
typedef void(* | aiot_mqtt_recv_handler_t) (void *handle, const aiot_mqtt_recv_t *packet, void *userdata) |
MQTT报文接收回调函数原型 更多... | |
typedef void(* | aiot_mqtt_event_handler_t) (void *handle, const aiot_mqtt_event_t *event, void *userdata) |
MQTT事件回调函数 更多... | |
函数 | |
void * | aiot_mqtt_init (void) |
初始化mqtt实例并设置默认参数 更多... | |
int32_t | aiot_mqtt_setopt (void *handle, aiot_mqtt_option_t option, void *data) |
设置mqtt参数 更多... | |
int32_t | aiot_mqtt_deinit (void **handle) |
释放mqtt实例句柄的资源 更多... | |
int32_t | aiot_mqtt_connect (void *handle) |
与MQTT服务器建立连接 更多... | |
int32_t | aiot_mqtt_disconnect (void *handle) |
与MQTT服务器断开连接 更多... | |
int32_t | aiot_mqtt_heartbeat (void *handle) |
发送MQTT PINGREQ报文, 用于维持心跳 更多... | |
int32_t | aiot_mqtt_process (void *handle) |
此函数用于处理定时心跳发送和qos1消息的重传逻辑 更多... | |
int32_t | aiot_mqtt_pub (void *handle, char *topic, uint8_t *payload, uint32_t payload_len, uint8_t qos) |
发送一条PUBLISH报文到MQTT服务器, QoS为0, 用于发布指定的消息 更多... | |
int32_t | aiot_mqtt_sub (void *handle, char *topic, aiot_mqtt_recv_handler_t handler, uint8_t qos, void *userdata) |
发送一条mqtt SUBSCRIBE报文到MQTT服务器, 用于订阅指定的topic 更多... | |
int32_t | aiot_mqtt_unsub (void *handle, char *topic) |
发送一条mqtt UNSUBSCRIBE报文到MQTT服务器, 用于取消订阅指定的topic 更多... | |
int32_t | aiot_mqtt_recv (void *handle) |
尝试从网络上接收MQTT报文 更多... | |
int32_t | aiot_mqtt_connect_v5 (void *handle, will_message_t *will_message, mqtt_properties_t *conn_prop) |
与MQTT服务器建立连接. 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0 更多... | |
int32_t | aiot_mqtt_pub_v5 (void *handle, char *topic, uint8_t *payload, uint32_t payload_len, uint8_t qos, uint8_t retain, mqtt_properties_t *pub_prop) |
发送一条PUBLISH报文到MQTT服务器, QoS为0, 用于发布指定的消息 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0 更多... | |
int32_t | aiot_mqtt_disconnect_v5 (void *handle, uint8_t reason_code, mqtt_properties_t *disconn_property) |
与MQTT服务器断开连接 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0 更多... | |
int32_t | aiot_mqtt_sub_v5 (void *handle, char *topic, sub_options_t *opts, aiot_mqtt_recv_handler_t handler, void *userdata, mqtt_properties_t *sub_prop) |
发送一条mqtt SUBSCRIBE报文到MQTT服务器, 用于订阅指定的topic 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0 更多... | |
int32_t | aiot_mqtt_unsub_v5 (void *handle, char *topic, mqtt_properties_t *unsub_prop) |
发送一条mqtt UNSUBSCRIBE报文到MQTT服务器, 用于取消订阅指定的topic 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0 更多... | |
MQTT模块头文件, 提供用MQTT协议连接阿里云物联网平台的能力
MQTT模块用于建立与阿里云物联网平台的连接, API使用流程如下:
#define USER_PROPERTY_MAX (20) |
typedef void(* aiot_mqtt_recv_handler_t) (void *handle, const aiot_mqtt_recv_t *packet, void *userdata) |
MQTT报文接收回调函数原型
[in] | handle | MQTT实例句柄 |
[in] | packet | MQTT报文结构体, 存放收到的MQTT报文 |
[in] | userdata | 用户上下文 |
typedef void(* aiot_mqtt_event_handler_t) (void *handle, const aiot_mqtt_event_t *event, void *userdata) |
MQTT事件回调函数
当MQTT内部事件被触发时, 调用此函数. 如连接成功/断开连接/重连成功
MQTT报文类型
传入aiot_mqtt_recv_handler_t 的MQTT报文类型
枚举值 | |
---|---|
AIOT_MQTTDISCONNEVT_NETWORK_DISCONNECT |
MQTT实例网络连接由于网络故障而断开 |
AIOT_MQTTDISCONNEVT_HEARTBEAT_DISCONNECT |
MQTT实例网络连接由于心跳丢失超过指定次数(AIOT_MQTTOPT_HEARTBEAT_MAX_LOST )而断开 |
enum aiot_mqtt_option_t |
aiot_mqtt_setopt 函数的option参数. 对于下文每一个选项中的数据类型, 指的是aiot_mqtt_setopt 中的data参数的数据类型
data的数据类型是char *时, 以配置AIOT_MQTTOPT_HOST 为例:
char *host = "xxx";
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_HOST, host);
data的数据类型是其他数据类型时, 以配置AIOT_MQTTOPT_PORT 为例:
uint16_t port = 443;
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_PORT, (void *)&port);
枚举值 | |||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
AIOT_MQTTOPT_HOST |
MQTT 服务器的域名地址或者ip地址 阿里云物联网平台域名地址列表(必须使用自己的product key替换${pk}): 使用tcp或tls证书方式建联:
使用tls psk方式建联:
使用tls x509客户端证书方式建联:
数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_PORT |
MQTT 服务器的端口号 连接阿里云物联网平台时:
数据类型: (uint16_t *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_PRODUCT_KEY |
设备的product key, 可从阿里云物联网平台控制台获取 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_DEVICE_NAME |
设备的device name, 可从阿里云物联网平台控制台获取 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_DEVICE_SECRET |
设备的device secret, 可从阿里云物联网平台控制台获取 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_EXTEND_CLIENTID |
设备连接阿里云物联网平台时的扩展clientid 若需要上报模组商id和模组id以及os信息, 按以下格式填写: "mid=<模组ID>,pid=<模组商ID>,os=<操作系统>" 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_SECURITY_MODE |
设备连接阿里云物联网平台时的安全模式, 使用标准的tcp或tls时无需配置 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_USERNAME |
使用自定义连接凭据连接mqtt服务器时, 凭据的username 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_PASSWORD |
使用自定义连接凭据连接mqtt服务器时, 凭据的password 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_CLIENTID |
使用自定义连接凭据连接mqtt服务器时, 凭据的clientid 数据类型: (char *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_KEEPALIVE_SEC |
MQTT建联时, CONNECT报文中的心跳间隔参数 受阿里云物联网平台限制, 取值范围为30 ~ 1200s
数据类型: (uint16_t *) 取值范围: 30 ~ 1200s 默认值: 1200s | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_CLEAN_SESSION |
MQTT建联时, CONNECT报文中的clean session参数
数据类型: (uint8_t *) 取值范围: 0, 1 默认值: 1 | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_NETWORK_CRED |
MQTT建联时, 网络使用的安全凭据 该配置项用于为底层网络配置aiot_sysdep_network_cred_t 安全凭据数据
数据类型: (aiot_sysdep_network_cred_t *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_CONNECT_TIMEOUT_MS |
MQTT建联时, 建立网络连接的超时时间 指建立socket连接的超时时间 数据类型: (uint32_t *) 默认值: (5 *1000) ms | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_HEARTBEAT_INTERVAL_MS |
配置MQTT PINGREQ报文发送时间间隔. (心跳发送间隔) 数据类型: (uint32_t *) 默认值: (25 * 1000) ms | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_HEARTBEAT_MAX_LOST |
配置MQTT PINGRESP报文允许连续丢失的最大次数, 当超过这个次数时, 触发重连机制 数据类型: (uint8_t *) 默认值: (2) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_RECONN_ENABLED |
打开/关闭MQTT重连机制 数据类型: (uint8_t *) 取值范围: 0, 1 默认值: 1 | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_RECONN_INTERVAL_MS |
当由于心跳丢失或者网络断开触发重连机制时, 尝试重连的时间间隔 数据类型: (uint32_t *) 默认值: (2 * 1000) ms | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_SEND_TIMEOUT_MS |
MQTT发送数据时, 在协议栈花费的最长时间 数据类型: (uint32_t *) 默认值: (5 * 1000) ms | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_RECV_TIMEOUT_MS |
MQTT接收数据时, 在协议栈花费的最长时间 数据类型: (uint32_t *) 默认值: (5 * 1000) ms | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_REPUB_TIMEOUT_MS |
QoS1消息重发间隔 当发送qos1 MQTT PUBLISH报文后, 如果在AIOT_MQTTOPT_REPUB_TIMEOUT_MS 时间内未收到mqtt PUBACK报文, aiot_mqtt_process 会重新发送此qo1 MQTT PUBLISH报文, 直到收到PUBACK报文为止 数据类型: (uint32_t *) 默认值: (3 * 1000) ms | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_DEINIT_TIMEOUT_MS |
销毁MQTT实例时, 等待其他api执行完毕的时间 当调用aiot_mqtt_deinit 销毁MQTT实例时, 若继续调用其他aiot_mqtt_xxx API, API会返回STATE_USER_INPUT_EXEC_DISABLED 错误 此时, 用户应该停止调用其他aiot_mqtt_xxx API 数据类型: (uint32_t *) 默认值: (2 * 1000) ms | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_RECV_HANDLER |
从MQTT服务器收取的数据从此默认回调函数进行通知
数据类型: ( aiot_mqtt_recv_handler_t ) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_EVENT_HANDLER |
MQTT客户端内部发生的事件会从此回调函数进行通知, 如上线/断线/重新上线 数据类型: ( aiot_mqtt_event_handler_t ) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_APPEND_TOPIC_MAP |
可在MQTT建立连接之前配置MQTT topic与其对应的回调函数 数据类型: ( aiot_mqtt_topic_map_t ) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_REMOVE_TOPIC_MAP |
取消之前建立的MQTT topic与其回调函数的对应关系 数据类型: ( aiot_mqtt_topic_map_t ) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_APPEND_REQUESTID |
在publish消息的topic上附加请求ID字符串, 用于全链路日志追踪 数据类型: (uint8_t *) 默认值: 0 配置为0则不附加请求ID字符串, 配置为1将附加请求ID字符串 | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_USERDATA |
用户需要SDK暂存的上下文
数据类型: (void *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_MAX_REPUB_NUM |
SDK缓存的QOS 1消息的数量的最大值 当发送qos1 MQTT PUBLISH报文后, 该消息会加入到一个重传的list中,收到pub ack报文后该消息会从该list中删除 该list需要设置一个最大值, 否则该list在弱网情况下可能会一直膨胀,直到内存开销耗完 数据类型: (uint16_t *) 默认值: 20 | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_VERSION |
设置MQTT 协议的版本号
数据类型: (void *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_ASSIGNED_CLIENTID |
MQTT 5.0特性. 设置是否要使能assigned clentid功能
数据类型: (void *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_FLOW_CONTROL_ENABLED |
MQTT 5.0特性. 设置是否要使能设备端流控功能
数据类型: (void *) | ||||||||||||||||||||||||||||||
AIOT_MQTTOPT_MAX |
void* aiot_mqtt_init | ( | void | ) |
初始化mqtt实例并设置默认参数
非NULL | MQTT实例句柄 |
NULL | 初始化失败, 一般是内存分配失败导致 |
int32_t aiot_mqtt_setopt | ( | void * | handle, |
aiot_mqtt_option_t | option, | ||
void * | data | ||
) |
设置mqtt参数
下面列出常用的配置选项, 至少需要配置以下选项才可使用MQTT的基本功能
其余配置选项均设有默认值, 可按业务需要进行调整
AIOT_MQTTOPT_HOST
: 配置连接的阿里云MQTT站点地址AIOT_MQTTOPT_PORT
: 配置连接的阿里云MQTT站点端口号AIOT_MQTTOPT_PRODUCT_KEY
: 配置设备的 productKeyAIOT_MQTTOPT_DEVICE_NAME
: 配置设备的 deviceNameAIOT_MQTTOPT_DEVICE_SECRET
: 配置设备的 deviceSecretAIOT_MQTTOPT_NETWORK_CRED
: 配置建立MQTT连接时的安全凭据AIOT_MQTTOPT_RECV_HANDLER
: 配置默认的数据接收回调函数AIOT_MQTTOPT_EVENT_HANDLER
: 配置MQTT事件通知回调函数[in] | handle | mqtt句柄 |
[in] | option | 配置选项, 更多信息请参考aiot_mqtt_option_t |
[in] | data | 配置选项数据, 更多信息请参考aiot_mqtt_option_t |
<STATE_SUCCESS | 参数设置失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 参数设置成功 |
int32_t aiot_mqtt_deinit | ( | void ** | handle | ) |
释放mqtt实例句柄的资源
[in] | handle | 指向mqtt实例句柄的指针 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_connect | ( | void * | handle | ) |
与MQTT服务器建立连接
使用aiot_mqtt_setopt 配置的mqtt连接参数连接mqtt服务器, 使用的建联参数按如下顺序选择
[in] | handle | MQTT实例句柄 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
当配置AIOT_MQTTOPT_USERNAME , AIOT_MQTTOPT_PASSWORD 和AIOT_MQTTOPT_CLIENTID 配置自定义连接凭据时,
此函数会忽略AIOT_MQTTOPT_PRODUCT_KEY , AIOT_MQTTOPT_DEVICE_NAME 和AIOT_MQTTOPT_DEVICE_SECRET,
直接使用自定义凭据连接指定的MQTT服务器
int32_t aiot_mqtt_disconnect | ( | void * | handle | ) |
与MQTT服务器断开连接
向MQTT服务器发送MQTT DISCONNECT报文, 然后断开网络连接
如果需要再次与MQTT服务器建立连接, 调用aiot_mqtt_connect 即可
[in] | handle | MQTT实例句柄 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_heartbeat | ( | void * | handle | ) |
发送MQTT PINGREQ报文, 用于维持心跳
aiot_mqtt_process 包含了定时发送心跳的机制, 如果有特殊需要的话, 可以使用此函数直接发送心跳报文
[in] | handle | MQTT实例句柄 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_process | ( | void * | handle | ) |
此函数用于处理定时心跳发送和qos1消息的重传逻辑
[in] | handle | MQTT实例句柄 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
该函数为非阻塞, 需要间歇性被调用, 调用间隔应当小于AIOT_MQTTOPT_HEARTBEAT_INTERVAL_MS 和AIOT_MQTTOPT_REPUB_TIMEOUT_MS 时间内没有收到mqtt的最小值,
以确保心跳发送和QoS1消息的重传逻辑正常工作
int32_t aiot_mqtt_pub | ( | void * | handle, |
char * | topic, | ||
uint8_t * | payload, | ||
uint32_t | payload_len, | ||
uint8_t | qos | ||
) |
发送一条PUBLISH报文到MQTT服务器, QoS为0, 用于发布指定的消息
[in] | handle | MQTT实例句柄 |
[in] | topic | 指定MQTT PUBLISH报文的topic |
[in] | payload | 指定MQTT PUBLISH报文的payload |
[in] | payload_len | 指定MQTT PUBLISH报文的payload_len |
[in] | qos | 指定mqtt的qos值, 仅支持qos0和qos1 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_sub | ( | void * | handle, |
char * | topic, | ||
aiot_mqtt_recv_handler_t | handler, | ||
uint8_t | qos, | ||
void * | userdata | ||
) |
发送一条mqtt SUBSCRIBE报文到MQTT服务器, 用于订阅指定的topic
[in] | handle | MQTT实例句柄 |
[in] | topic | 指定MQTT SUBSCRIBE报文的topic |
[in] | handler | 与topic对应的MQTT PUBLISH报文回调函数, 当有消息发布到topic时, 该回调函数被调用 若handler为NULL传入, 则SDK调用AIOT_MQTTOPT_RECV_HANDLER 配置的回调函数 若多次调用aiot_mqtt_sub()并对同一topic指定不同的handler, 有消息到达时不同handler都会被调用到 |
[in] | qos | 指定topic期望mqtt服务器支持的最大qos值, 仅支持qos0和qos1 |
[in] | userdata | 可让SDK代为保存的用户上下文, 当回调函数被调用时, 此上下文会通过handler传回给用户 若未指定该上下文, 那么通过AIOT_MQTTOPT_USERDATA 配置的上下文会通过handler传回给用户 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_unsub | ( | void * | handle, |
char * | topic | ||
) |
发送一条mqtt UNSUBSCRIBE报文到MQTT服务器, 用于取消订阅指定的topic
[in] | handle | MQTT实例句柄 |
[in] | topic | 指定MQTT UNSUBSCRIBE报文的topic |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_recv | ( | void * | handle | ) |
尝试从网络上接收MQTT报文
除了从网络上接收MQTT报文之外, 本函数也包含了重连机制
[in] | handle |
STATE_SYS_DEPEND_NWK_READ_LESSDATA | 执行成功, 此时网络上暂无可以收取的MQTT报文 |
>=STATE_SUCCESS | 执行成功 |
其他返回值 | 执行失败, 更多信息请参考aiot_state_api.h |
当网络连接正常并且aiot_mqtt_deinit 未被调用时, 该函数为阻塞, 需要持续被调用
int32_t aiot_mqtt_connect_v5 | ( | void * | handle, |
will_message_t * | will_message, | ||
mqtt_properties_t * | conn_prop | ||
) |
与MQTT服务器建立连接. 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0
使用aiot_mqtt_setopt 配置的mqtt连接参数连接mqtt服务器, 使用的建联参数按如下顺序选择
[in] | handle | MQTT实例句柄 |
[in] | will_message | MQTT建连报文的遗嘱消息,若不存在,设置为NULL |
[in] | conn_prop | 指定MQTT CONNECT报文的属性 |
STATE_MQTT_INVALID_PROTOCOL_VERSION | mqtt协议的版本号不对, 没有通过AIOT_MQTTOPT_VERSION将版本号将设置为5.0 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
当配置AIOT_MQTTOPT_USERNAME , AIOT_MQTTOPT_PASSWORD 和AIOT_MQTTOPT_CLIENTID 配置自定义连接凭据时,
此函数会忽略AIOT_MQTTOPT_PRODUCT_KEY , AIOT_MQTTOPT_DEVICE_NAME 和AIOT_MQTTOPT_DEVICE_SECRET,
直接使用自定义凭据连接指定的MQTT服务器
int32_t aiot_mqtt_pub_v5 | ( | void * | handle, |
char * | topic, | ||
uint8_t * | payload, | ||
uint32_t | payload_len, | ||
uint8_t | qos, | ||
uint8_t | retain, | ||
mqtt_properties_t * | pub_prop | ||
) |
发送一条PUBLISH报文到MQTT服务器, QoS为0, 用于发布指定的消息 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0
[in] | handle | MQTT实例句柄 |
[in] | topic | 指定MQTT PUBLISH报文的topic |
[in] | payload | 指定MQTT PUBLISH报文的payload |
[in] | payload_len | 指定MQTT PUBLISH报文的payload_len |
[in] | qos | 指定mqtt的qos值, 仅支持qos0和qos1 |
[in] | retain | 指定是否为保留消息 |
[in] | pub_prop | 指定MQTT PUB报文的属性 |
STATE_MQTT_INVALID_PROTOCOL_VERSION | mqtt协议的版本号不对, 没有通过AIOT_MQTTOPT_VERSION将版本号将设置为5.0 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_disconnect_v5 | ( | void * | handle, |
uint8_t | reason_code, | ||
mqtt_properties_t * | disconn_property | ||
) |
与MQTT服务器断开连接 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0
向MQTT服务器发送MQTT DISCONNECT报文, 然后断开网络连接
如果需要再次与MQTT服务器建立连接, 调用aiot_mqtt_connect 即可
[in] | handle | MQTT实例句柄 |
[in] | reason_code | 指定MQTT DISCONNECT的原因 |
[in] | disconn_property | 指定MQTT DISCONNECT报文的属性 |
STATE_MQTT_INVALID_PROTOCOL_VERSION | mqtt协议的版本号不对, 没有通过AIOT_MQTTOPT_VERSION将版本号将设置为5.0 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_sub_v5 | ( | void * | handle, |
char * | topic, | ||
sub_options_t * | opts, | ||
aiot_mqtt_recv_handler_t | handler, | ||
void * | userdata, | ||
mqtt_properties_t * | sub_prop | ||
) |
发送一条mqtt SUBSCRIBE报文到MQTT服务器, 用于订阅指定的topic 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0
[in] | handle | MQTT实例句柄 |
[in] | topic | 指定MQTT SUBSCRIBE报文的topic |
[in] | opts | 订阅选项 |
[in] | handler | 与topic对应的MQTT PUBLISH报文回调函数, 当有消息发布到topic时, 该回调函数被调用 若handler为NULL传入, 则SDK调用AIOT_MQTTOPT_RECV_HANDLER 配置的回调函数 若多次调用aiot_mqtt_sub()并对同一topic指定不同的handler, 有消息到达时不同handler都会被调用到 |
[in] | userdata | 可让SDK代为保存的用户上下文, 当回调函数被调用时, 此上下文会通过handler传回给用户 若未指定该上下文, 那么通过AIOT_MQTTOPT_USERDATA 配置的上下文会通过handler传回给用户 |
[in] | sub_prop | 指定MQTT SUBSCRIBE报文的属性 |
STATE_MQTT_INVALID_PROTOCOL_VERSION | mqtt协议的版本号不对, 没有通过AIOT_MQTTOPT_VERSION将版本号将设置为5.0 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |
int32_t aiot_mqtt_unsub_v5 | ( | void * | handle, |
char * | topic, | ||
mqtt_properties_t * | unsub_prop | ||
) |
发送一条mqtt UNSUBSCRIBE报文到MQTT服务器, 用于取消订阅指定的topic 以MQTT 5.0协议的方式接入, 支持5.0的特性. 在调用这个接口前, 需要确保已经通过AIOT_MQTTOPT_VERSION的方式, 设置过版本号为AIOT_MQTT_VERSION_5_0
[in] | handle | MQTT实例句柄 |
[in] | topic | 指定MQTT UNSUBSCRIBE报文的topic |
[in] | unsub_prop | 指定MQTT UNSUBSCRIBE报文的属性 |
STATE_MQTT_INVALID_PROTOCOL_VERSION | mqtt协议的版本号不对, 没有通过AIOT_MQTTOPT_VERSION将版本号将设置为5.0 |
<STATE_SUCCESS | 执行失败, 更多信息请参考aiot_state_api.h |
>=STATE_SUCCESS | 执行成功 |