MQTT协议接入

MQTT简介

MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)协议是即时通信协议,是物联网的重要组成部分。

协议特点

MQTT协议是为大量计算能力有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,它具有以下主要的几项特性:

1.使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合;

2.对负载内容屏蔽的消息传输;

3.使用 TCP/IP 提供网络连接;

4.小型传输,开销很小(固定长度的头部是 2 字节),协议交换最小化,以降低网络流量;

5.使用 Last Will 和 Testament 特性通知有关各方客户端异常中断的机制;

6.有三种消息发布服务质量:

    “至多一次”,消息至多发送一次。

    “至少一次”,确保消息到达,但消息重复可能会发生。

    “只有一次”,确保消息到达一次。

操作前提

1.已创建好产品和设备(产品管理、设备管理)
2.定义好产品模型(模型管理)

产品管理设备管理模型管理

获取连接认证参数

设备通过mqtt协议连接云服务,必须认证通过后才能成功建立连接。

【注意】直连设备(网关设备和普通设备)才允许连接

1)建立连接前先从平台获取认证需要的参数
参数 说明 获取路径
devId 设备ID 用户添加设备时输入的“设备ID”,在“设备管理”中可查看
pk 产品PK 平台“设备管理”,根据设备ID找到设备,点击列表右侧的“查看”,复制“设备信息”中的“产品PK”。
devSecret 设备秘钥 平台“设备管理”,根据设备ID找到设备,点击列表右侧的“查看”,复制“设备信息”中的“devSecret”。
2)构造MQTT连接的参数
参数 说明 构造方式
clientId 客户端ID dev:{pk}:{devId}
username 用户名 {hashMethod}:{random}
password 密码 hash(pk+devId+devSecret+random),加密密钥:devSecret。

【说明】

(1)参数间使用“:”隔开。
(2){hashMethod}支持:HmacMD5、HmacSHA1、HmacSHA256 和 HmacSHA512。
(3)password中加密使用的hashMethod、random需跟username中一致。

参数构造实例

Eg:pk=’pk123$’,devId=’1001$’,devSecret=’secret123$’,使用HashMD5方式进行加密,随机字符(random)为’20191108’。
clientId = dev:pk123$:1001$
username = HashMD5:20191108
password = c0608e3abe2f058df1d33020f963dbaf
password是通过HashMD5方法加密后得到。
要加密的字符串:pk123$1001$secret123$20191108,加密密钥:secret123$,加密后得到“c0608e3abe2f058df1d33020f963dbaf”。

在线工具

接入详情

使用MQTT.fx接入

使用SDK接入

results matching ""

    No results matching ""

    results matching ""

      No results matching ""