本文档以MQTT.fx为例,介绍使用第三方软件以MQTT协议接入物联网平台。MQTT.fx是一款基于Eclipse Paho,使用Java语言编写的MQTT客户端工具。支持通过Topic订阅和发布消息。
前提条件
已在物联网平台控制台创建产品和设备,并获取设备证书信息(ProductKey、DeviceName和DeviceSerect)。创建产品和设备具体操作细节,请参考创建产品、单个创建设备和批量创建设备。
MQTT.fx接入
下载并安装MQTT.fx软件。请访问MQTT.fx官网。
设置连接参数。物联网平台目前支持两种连接模式,不同模式设置参数不同。
单击下载Password生成小工具。
使用Password生成小工具的输入参数:
手动生成方法如下:
productKey:设备所属产品Key。可在控制台设备详情页查看。
deviceName:设备名称。可在控制台设备详情页查看。
deviceSecret:设备密钥。可在控制台设备详情页查看。
timestamp:(可选)时间戳。
clientId:设备的ID信息,与Client ID中一致。
method:选择签名算法类型,与Client ID中确定的加密方法一致。
为设备的ID信息。可取任意值,长度在64字符以内。建议使用设备的MAC地址或SN码。
为安全模式,TCP直连模式设置为securemode=3,TLS直连为securemode=2。
为算法类型,支持hmacmd5和hmacsha1。
TCP直连:Client ID中securemode=3,无需设置SSL/TLS信息。
TLS直连:Client ID中securemode=2,需要设置SSL/TLS信息。
拼接参数。
提交给服务器的clientId、deviceName、productKey和timestamp(timestamp为非必选参数)参数及参数值依次拼接。
本例中拼接结果为:
clientId12345deviceNamedeviceproductKeyalxxxxxxxxx
加密。
通过Client ID中确定的加密方法,使用设备deviceSecret,将拼接结果加密。
假设设备的deviceSecret值为abc123,加密计算格式为
hmacsha1(abc123,clientId12345deviceNamedeviceproductKeyalxxxxxxxxxx)
参数 说明 Profile Name 输入您的自定义名称。 Profile Type 选择为 MQTT Broker。 MQTT Broker Profile Settings Broker Address 连接域名。 格式:。
其中,需替换为您物联网平台服务所在地域的代码。地域代码,请参见地域和可用区。如:alxxxxxxxxxx.iot-as-mqtt.cn-shanghai.aliyuncs.com。
Broker Port 设置为。 Client ID 填写mqttClientId,用于MQTT的底层协议报文。 格式固定:。
完整示例:
12345|securemode=3,signmethod=hmacsha1|
。其中,
说明 输入Client ID信息后,请勿单击Generate。General General栏目下的设置项可保持系统默认,也可以根据您的具体需求设置。
单击User Credentials,设置User Name和Password。
参数 说明 User Name 由设备名DeviceName、符号(&)和产品ProductKey组成。 固定格式:。
完整示例如:device&alxxxxxxxxxx。
Password 密码由参数值拼接加密而成。 您可以使用物联网平台提供的生成工具自动生成Password,也可以手动生成Password。
(可选)TCP直连模式(即securemode=3)下,无需设置SSL/TLS信息,直接进入下一步。
TLS直连模式(即securemode=2)下,需要选择SSL/TLS,勾选 Enable SSL/TLS,设置Protocol。建议Protocol选择为TLSv1.2。
填写完成后,单击OK。
下行通信测试
从物联网平台发送消息,在MQTT.fx上接收消息,测试MQTT.fx与物联网平台连接是否成功 。
在MQTT.fx上,单击Subscribe。
输入一个设备具有订阅权限的Topic,单击Subscribe,订阅这个Topic。
订阅成功后,该Topic将显示在列表中。
在物联网平台控制台中,该设备的设备详情页,Topic列表下,单击已订阅的Topic对应的发布消息操作按钮。
上行通信测试
在MQTT.fx上发送消息,通过查看设备日志,测试MQTT.fx与物联网平台连接是否成功 。
在MQTT.fx上,单击Publish。
在物联网平台控制台中,该设备的设备详情>日志服务>上行消息分析栏下,查看上行消息。
您还可以复制MessageID,在消息内容查询中,选择原始数据查看具体消息内容。
查看日志
在MQTT.fx上,单击Log查看操作日志和错误提示日志。
