简介
使用AT方式连接阿里云分为一机一密和一型一密两种方式,其中一机一密又包括HTTP认证二次连接和MQTT直连两种方式
- 关联文档和使用工具:
- 阿里云平台
准备工作
-
开发板一套,包括天线SIM卡,USB线,并烧录AT固件
-
PC电脑,串口工具
-
准备设备证书及产品证书
注意:下方证书信息仅为本教程使用,用户需要使用自己的证书信息
--设备证书
{
"ProductKey": "k1tnzv8Dv17",
"DeviceName": "867523077968777",
"DeviceSecret": "a4085dd3e31abb43f1d46e1e3bdbf9c3"
}
--产品证书
{
"ProductSecret": "RQGDV0tXLvAO4Q6K",
"ProductKey": "k1tnzv8Dv17"
}
阿里云操作
产品操作
打开阿里云平台找到物联网平台,开通业务后进入控制台。
点开设备管理的产品页面,点击新建产品。根据需求和图示说明创建产品。
设备操作
创建产品完成后就可以进入设备页面添加设备,在对应产品页面进入设备管理,按照提示添加设备
(在做正式产品时建议使用imei为devicename,方便后期维护)
连接阿里云
一机一密AT HTTP鉴权连接
- 首先需要使用HmacMD5计算哈希值用于签名,使用网址:在线加/解密工具
明文: clientId867523077968777deviceName867523077968777productKeyk1tnzv8Dv17
秘钥: a4085dd3e31abb43f1d46e1e3bdbf9c3
结果: fd0cc8059488927f7211c69f85e4278d
- 拼接DOWNLOAD参数
productKey=k1tnzv8Dv17&sign=fd0cc8059488927f7211c69f85e4278d&clientId=867523077968777&deviceName=867523077968777
-
AT交互流程如下所示
-
激活网络
[12:09:17.115]发→◇AT+CGATT?
□
[12:09:17.136]收←◆AT+CGATT?
+CGATT: 1
OK
[12:09:24.715]发→◇AT+SAPBR=3,1,"CONTYPE","GPRS"
□
[12:09:24.822]收←◆AT+SAPBR=3,1,"CONTYPE","GPRS"
OK
[12:09:31.663]发→◇AT+SAPBR=3,1,"APN","CMIOT"
□
[12:09:31.670]收←◆AT+SAPBR=3,1,"APN","CMIOT"
OK
[12:09:32.899]发→◇AT+SAPBR=1,1
□
[12:09:32.901]收←◆AT+SAPBR=1,1
OK
- 初始化HTTP
[12:09:42.891]发→◇AT+HTTPINIT
□
[12:09:42.933]收←◆AT+HTTPINIT
OK
- 写入网址URL
[12:09:51.773]发→◇AT+HTTPPARA="URL",https://iot-auth.cn-shanghai.aliyuncs.com/auth/devicename
□
[12:09:51.776]收←◆AT+HTTPPARA="URL",https://iot-auth.cn-shanghai.aliyuncs.com/auth/devicename
OK
- 设置本次请求的hearder,注意"Content-type: " 后面有一个空格
[12:09:55.361]发→◇AT+HTTPPARA="USER_DEFINED","Content-type: application/x-www-form-urlencoded"
□
[12:09:55.372]收←◆AT+HTTPPARA="USER_DEFINED","Content-type: application/x-www-form-urlencoded"
OK
- 配置写入DOWNLOAD参数指令,注意这个112是DOWNLOAD参数的数据长度(以字节为单位),实际使用时,要根据自己的数据长度进行修改,切记!!! 待出现DOWNLOAD后发送通过前文计算拼接出来的DOWNLOAD参数
[13:09:05.246]发→◇AT+HTTPDATA=112,20000
□
[13:09:05.249]收←◆AT+HTTPDATA=112,20000
DOWNLOAD
- 写入DOWNLOAD参数,注意最好自己复制这串数据,然后修改具体的值,不要全部手动输入,否则很容易出问题,切记!!!
[13:09:10.735]发→◇productKey=k1tnzv8Dv17&sign=fd0cc8059488927f7211c69f85e4278d&clientId=867523077968777&deviceName=867523077968777
□
[13:09:10.740]收←◆
OK
- HTTPACTION的信息上报,正常的话会回复状态码200
[13:09:16.378]发→◇AT+HTTPACTION=1
□
[13:09:16.381]收←◆AT+HTTPACTION=1
OK
- 收到信息上报正常回复状态码200,收到返回数据长度为124
[13:09:18.025]收←◆
+HTTPACTION: 1,200,124
- 读取请求结果,注意,HTTPREAD返回的数据中有iotId和iotToken,其中iotId的值为MQTT client的用户名,iotToken的值为MQTT client的密码
[13:09:51.867]发→◇AT+HTTPREAD
□
[13:09:51.870]收←◆AT+HTTPREAD
+HTTPREAD: 124
{"code":200,"data":{"iotId":"aVigmpIxpw7uSNdIeH7Nk1tnz0","iotToken":"76cb59e7dc35462588303547d30db561"},"message":"success"}
OK
- 配置连接阿里云,注意,第一个值为clientId,第二个值为iotId,第三个值为iotToken
[13:12:32.942]发→◇AT+MCONFIG="867523077968777","aVigmpIxpw7uSNdIeH7Nk1tnz0","76cb59e7dc35462588303547d30db561"
□
[13:12:32.945]收←◆AT+MCONFIG="867523077968777","aVigmpIxpw7uSNdIeH7Nk1tnz0","76cb59e7dc35462588303547d30db561"
OK
- 建立连接,注意,收到CONNECT OK后立刻发送指令建立会话,不然会被踢,一定注意!!!
[13:12:51.493]发→◇AT+SSLMIPSTART="a1qsHBbKtmc.iot-as-mqtt.cn-shanghai.aliyuncs.com",1883
□
[13:12:51.496]收←◆AT+SSLMIPSTART="a1qsHBbKtmc.iot-as-mqtt.cn-shanghai.aliyuncs.com",1883
OK
[13:12:52.911]收←◆
CONNECT OK
[13:12:53.182]发→◇AT+MCONNECT=1,120
□
[13:12:53.185]收←◆AT+MCONNECT=1,120
OK
[13:12:53.434]收←◆
CONNACK OK
- 连接成功
一机一密AT直连MQTT
- 当设备属于公共实例,使用一型一密预注册认证方式时,动态注册参数如下:
mqttClientId: clientId+"|securemode=3,signmethod=hmacsha1,timestamp=132323232|"
mqttUsername: deviceName+"&"+productKey
mqttPassword: sign_hmac(deviceSecret,content)
参数 | 说明 |
---|---|
clientId | 客户端ID:长度在64个字符内,建议使用IMEI或SN码方便区分不同客户端 |
securemode | 安全模式: 2 (TLS直连模式),3 (TCP直连模式) |
signmethod | 表示签名算法类型。支持hmacmd5,hmacsha1,hmacsha256。默认为hmacmd5 |
timestamp | 表示当前时间毫秒值,可以不传递 |
mqttPassword | 前文计算的签名值 |
-
AT交互流程如下所示
-
配置MQTT参数
[13:20:26.001]发→◇AT+MCONFIG="867523077968777|securemode=3,signmethod=hmacmd5|","867523077968777&k1tnzv8Dv17","fd0cc8059488927f7211c69f85e4278d"
□
[13:20:26.004]收←◆AT+MCONFIG="867523077968777|securemode=3,signmethod=hmacmd5|","867523077968777&k1tnzv8Dv17","fd0cc8059488927f7211c69f85e4278d"
OK
- 建立连接,注意,第一个参数需要根据实际项目productKey修改
[13:20:43.546]发→◇AT+SSLMIPSTART="k1tnzv8Dv17.iot-as-mqtt.cn-shanghai.aliyuncs.com",1883
□
[13:20:43.549]收←◆AT+SSLMIPSTART="k1tnzv8Dv17.iot-as-mqtt.cn-shanghai.aliyuncs.com",1883
OK
- 建立会话,注意,收到 CONNECT OK 后立刻发送指令建立会话,不然会被踢,一定注意!!!
[13:20:45.836]收←◆
CONNECT OK
[13:20:48.961]发→◇AT+MCONNECT=1,120
□
[13:20:48.964]收←◆AT+MCONNECT=1,120
OK
[13:20:49.179]收←◆
CONNACK OK
一型一密AT方式连接
- 一型一密与一机一密的主要区别在于第一次连接的时候需要根据协议请求秘钥,首先需要在阿里云打开动态注册开关,如下图所示
- 使用到的参数如下所示
{
"ProductSecret": "RQGDV0tXLvAO4Q6K",
"ProductKey": "k1tnzv8Dv17"
"DeviceName" "867523077968777"
}
明文:deviceName867523077968777productKeyk1tnzv8Dv17random123456
秘钥:RQGDV0tXLvAO4Q6K
HmacMD5计算结果:3679044753ee669aa19bf660e9492e84
DOWNLOAD参数
--random 为随机数,长度不定
productKey=k1tnzv8Dv17&deviceName=867523077968777&random=123456&sign=3679044753ee669aa19bf660e9492e84&signMethod=HmacMD5
- 当设备属于公共实例,使用一型一密预注册认证方式时,动态注册参数如下:
mqttClientId: clientId+"|securemode=2,authType=xxxx,random=xxxx,signmethod=xxxx|"
mqttUserName: deviceName+"&"+productKey
mqttPassword: sign_hmac(productSecret,content)
-
AT交互流程如下所示
-
激活网络,注意,先发送AT+CGATT?查询是否附着上GPRS数据网络,返回+CGATT: 1后,才能执行下面的三个 AT指令。
[13:21:13.901]发→◇AT+CGATT?
□
[13:21:13.902]收←◆AT+CGATT?
+CGATT: 1
OK
[13:21:23.900]发→◇AT+SAPBR=3,1,"CONTYPE","GPRS"
□
[13:21:23.902]收←◆AT+SAPBR=3,1,"CONTYPE","GPRS"
OK
[13:21:31.245]发→◇AT+SAPBR=3,1,"APN","CMIOT"
□
[13:21:31.248]收←◆AT+SAPBR=3,1,"APN","CMIOT"
OK
[13:21:38.659]发→◇AT+SAPBR=1,1
□
[13:21:38.661]收←◆AT+SAPBR=1,1
OK
- 初始化HTTP
[13:22:35.329]发→◇AT+HTTPINIT
□
[13:22:35.332]收←◆AT+HTTPINIT
OK
- 写入网址URL
[13:22:44.056]发→◇AT+HTTPPARA="URL","https://iot-auth.cn-shanghai.aliyuncs.com/auth/register/device"
□
[13:22:44.061]收←◆AT+HTTPPARA="URL","https://iot-auth.cn-shanghai.aliyuncs.com/auth/register/device"
OK
- 设置本次请求的hearder,注意"Content-type: " 后面有一个空格
[13:22:54.671]发→◇AT+HTTPPARA="USER_DEFINED","Content-Type: application/x-www-form-urlencoded"
□
[13:22:54.674]收←◆AT+HTTPPARA="USER_DEFINED","Content-Type: application/x-www-form-urlencoded"
OK
- 配置写入DOWNLOAD参数指令,注意这个120是DOWNLOAD参数的数据长度(以字节为单位),实际使用时,要根据自己的数据长度进行修改,切记!!! 待出现DOWNLOAD后发送通过前文计算拼接出来的DOWNLOAD参数
[13:23:11.437]发→◇AT+HTTPDATA=120,20000
□
[13:23:11.439]收←◆AT+HTTPDATA=120,20000
DOWNLOAD
- 写入DOWNLOAD参数,注意最好自己复制这串数据,然后修改具体的值,不要全部手动输入,否则很容易出问题,切记!!!
[13:23:16.944]发→◇productKey=k1tnzv8Dv17&deviceName=868488076506128&random=123456&sign=20558baadb2a0b04847767980f0ee67b&signMethod=HmacMD5
□
[13:23:16.947]收←◆
OK
- HTTPACTION的信息上报,正常的话会回复状态码200
[13:23:26.653]发→◇AT+HTTPACTION=1
□
收←◆AT+HTTPACTION=1
OK
- 收到信息上报正常回复状态码200,收到返回数据长度为149
收←◆
+HTTPACTION: 1,200,149
- 读取请求结果
发→◇AT+HTTPREAD
收←◆AT+HTTPREAD
+HTTPREAD: 149
{"code":200,"data":{"deviceName":"867523077968777","deviceSecret":"a4085dd3e31abb43f1d46e1e3bdbf9c3","productKey":"k1tnzv8Dv17"},"message":"success"}
OK
发布与订阅消息
发布消息
- 发布Qos0消息
[13:31:06.798]发→◇AT+MPUB="/k1tnzv8Dv17/867523077968777/user/update",0,0,"HelloWorld"
□
[13:31:06.802]收←◆AT+MPUB="/k1tnzv8Dv17/867523077968777/user/update",0,0,"HelloWorld"
OK
- 发布Qos1消息,注意,Qos1 消息必须等到PUBACK返回,才能发下一条消息
[13:31:09.408]发→◇AT+MPUB="/k1tnzv8Dv17/867523077968777/user/update",1,0,"HelloWorld"
□
[13:31:09.412]收←◆AT+MPUB="/k1tnzv8Dv17/867523077968777/user/update",1,0,"HelloWorld"
OK
[13:31:09.709]收←◆
PUBACK
- 通过物联网平台-监控运维-日志服务可以直接查看日志信息
订阅消息
- 订阅主题
[13:32:58.568]发→◇AT+MSUB="/k1tnzv8Dv17/867523077968777/user/get",0
□
[13:32:58.572]收←◆AT+MSUB="/k1tnzv8Dv17/867523077968777/user/get",0
OK
[13:32:58.887]收←◆
SUBACK
- 设置收到数据时的打印方式
配置为0时主动上报到串口,上报的 URC 为
+MSUB:<topic>,<len>,<message>
配置为1时为缓存模式。有新订阅消息时,上报的URC为+MSUB:<store_addr>
[13:33:05.102]发→◇AT+MQTTMSGSET=0
□
[13:33:05.105]收←◆AT+MQTTMSGSET=0
OK
- 通过阿里云平台发布消息
[13:33:17.125]收 +MSUB: "/k1tnzv8Dv17/867523077968777/user/get",6 byte,123456