阿里云
一、阿里云物联网平台介绍
阿里云物联网平台(Alibaba Cloud IoT Platform)是阿里巴巴集团旗下的一个物联网平台,该平台是一个集成了设备接入、设备管理、数据安全通信、消息订阅、消息转发和数据服务(存储、分析、过滤、解析、集成等)等能力的一体化平台。向下支持连接海量设备,采集设备数据上云;向上提供云端 API,服务端可通过云端 SDK 调用云端 API 将指令下发至设备端,实现远程控制。
通过此链接你可以更好的了解到阿里云物联网平台:什么是物联网平台-阿里云帮助中心
二、演示功能概述
本文将演示如何使用 Air201模组和阿里云物联网平台实现物联网设备的连接与管理。通过以下步骤,我们将展示如何将 Air201模组连接到阿里云物联网平台,实现设备数据的远程上传和云端下发消息的功能。
2.1 准备硬件环境
- Air201模组:本文将以 Air201模组为例进行演示。
- SIM 卡:在中国大陆环境下,使用移动、电信、联通的物联网卡或手机卡均可。
- PC 电脑:推荐使用 Windows 10 及以上版本。
- 数据通信线:USB 转 Type-C 数据线。
2.2 配置软件环境
- Luatools 下载调试工具:由合宙推出,支持固件获取、固件打包、trace 打印及单机烧录等功能。
- 阿里云物联网平台:阿里云物联网平台提供设备接入、设备管理、数据安全通信、消息订阅、消息转发和数据服务等能力。
- 源码及固件:下载 Air201模组所需的底层 core 文件和脚本代码,并烧录到 Air201模组中。
2.3 连接阿里云物联网平台
- 在阿里云物联网平台上创建产品,配置认证方式等。
- 在 Air201模组上编写代码,实现与阿里云物联网平台的连接。
2.4 数据上传和接收
- 在 Air201模组上编写代码,实现每隔一定时间向阿里云物联网平台上传数据。
- 在阿里云物联网平台上创建消息主题,用于接收Air201模组发送的数据。
2.5 云端下发消息
- 在阿里云物联网平台上创建消息主题,用于向 Air201模组下发消息。
- 在Air201模组上编写代码,实现订阅云端下发的消息。
2.6 运行结果展示
- 通过 Luatools 工具查看 Air201模组上的日志,验证数据的上传和接收。
- 在阿里云物联网平台上查看数据接收和下发消息的效果。
通过以上步骤,我们将展示如何使用 Air201模组和阿里云物联网平台实现物联网设备的连接与管理。
三、演示硬件环境
3.1 开发板
本文以 Air201模组为例,如下图所示:
点击链接购买:合宙Air201模组淘宝购买链接 ;
此模组的详细使用说明参考:Air201 产品手册 。
3.2 SIM 卡
在中国大陆环境下,使用移动,电信,联通的物联网卡或者手机卡都可以。
3.3 PC 电脑
WIN10以及以上版本的WINDOWS系统。
3.4 数据通信线
1. USB 转 Type-C 数据线
它的一端是 USB 接口,另一端是 Type-C 接口。
四、演示软件环境
4.1 Luatools 下载调试工具
Luatools 工具由合宙推出,支持最新固件获取、固件打包、trace 打印及单机烧录等功能。
工具使用说明参考:Luatools 下载和详细使用
4.2 阿里云物联网平台
4.3 源码及固件
官网下载,底层 core 下载地址:LuatOS 底层 core 注:本 demo 使用如图所示固件
2. demo 位置
本 demo 为诸多云平台的集合型 demo,适用于如阿里云、百度云、OneNet 等诸多云平台,大
https://gitee.com/openLuat/LuatOS-Air201/tree/master/demo/iotcloud
3. 源码及固件已打包压缩,如下所示
压缩包中 core 文件夹存放的是固件,code 文件夹存放的是脚本代码。 大家在使用脚本代码时一定要记得修改参数,至于修改什么参数,后面演示时会告诉大家。
五、软硬件资料
5.1 IOT_CLOUD 介绍
众所周知,市面上有很多云平台,阿里云、腾讯云、中移 onenet、华为云、百度云、Tlink 云等等......并且每家都有自己的协议,工程师要移植不同的 SDK 代码或基于各家的手册文档对接不同的协议,看着都头大!!!
所以 iotcloud 应运而生!iotcloud 是合宙专门为了合并 iot 平台而制作的库,意在使用统一且极简的代码接入各个云平台,轻松实现云功能。用户无需为那么多云平台的接入而头疼,只需要极简的通用 API 即可轻松上云!并且因为通用,所以云平台之间的迁移也十分方便。
5.1.1 iotcloud 库介绍
iotcloud 库本质就是上层设计一套通用的 API,通过该库进行每个平台功能的对接。目前已经实现了各个平台的所有注册方式,其中自动注册会将相关验证信息保存 kv,随后使用此验证信息进行连接,通知针对每个平台添加了特有系统实现,比如设备上线通知,设备版本号上传,OTA 功能等,用户无需管理这些只需要注意相关下发消息做应用逻辑即可。
注意:阿里云物联网平台分为旧版公共实例、新版公共实例和企业版实例,企业版和新版我们可以看为一个使用,新旧公共实例要自行区别,大家可到物联网平台控制台的实例概览页签的公共实例卡片上查看是否有实例 ID,若没有则表示当前账号使用的是旧版公共实例,若有则是新版公共实例。
iotcloud 同时支持新版公共实例 / 旧版公共实例 / 企业实例,但新版公共实例和企业版实例需要多一个实例 ID 参数,下面会有说明,此处需要特别注意。
5.1.2 API 接口介绍
本教程所使用 API 接口参考:iotcloud API 接口介绍 - LuatOS 文档
5.2 Air201模组录说明
5.2.1 选择固件和脚本
1. 打开 Luatools 工具
2. 点击 项目管理测试
3. 根据图示操作
注意,大家只需要跟着做到第四步即可,第五步跟着后面的操作再做。
5.2.2 烧录
1. 将 Air201模组通过 USB 数据线连接至电脑,如下图所示:
2. 根据下方操作进行烧录
此时就需要大家先点击 Luatools 工具上的 下载底层与脚本/下载脚本,再执行下方操作了。
Air201进入boot下载模式,烧录固件和程序,需要将预留的测试点(Air201板子 B面图) 的BOOT 上拉到vdd_ext(A面USB旁边),之后上电开机,即可进入下载模式,下载完程序后将boot脚悬空。
Air201板子 A面图
Air201板子 B面图
5.2.3 BOOT模式下端口显示
判断是否进入 BOOT 模式:模块上电,此时在电脑的设备管理器中,查看串口设备, 会出现一个端口表示进入了 BOOT 下载模式,如下图所示:
一旦进入了boot下载模式,表示硬件连接上已经处于就绪状态,此时就可以使用Luatools工具进行烧录了!
六、功能验证
6.1 云平台准备
1. 登录官网 阿里云物联网平台 (aliyun.com) 并注册账号
2. 开通物联网平台服务
3. 试用物联网平台公共实例服务
新旧公共实例平台需要进行区分,参考 物联网平台新版公共实例、旧版公共实例和企业版实例类型、区别和开通使用_物联网平台(IoT)-阿里云帮助中心 (aliyun.com)
新版公共实例的实例概览页签显示实例 ID 值:
旧版公共实例的实力概览页不显示实例 ID 值
注意:如果使用的是新版公共实例,需要记住此时的实例 ID,后面会用到。
4. 创建产品
物联网平台--> 设备管理--> 产品--> 创建产品
配置信息,注意认证方式要选择设备秘钥
创建完成后,要记住此时的产品 ID(ProductKey),后面会用到
6.2 一型一密(免预注册,但需要是企业版实例平台)方式连接云平台
此方式极为简单,无需创建设备,他可以实现统一代码使用时动态进行设备注册,只需要三个参数,实例 ID,产品 ID(ProjectKey)和产品秘钥(ProductSecret),会自动用 IMEI 号作为设备名进行设备注册。
6.2.1 获取需要的三个参数
实例 ID 和产品 ID(ProjectKey)在上面准备阶段的时候已经拿到了,接下来我们查看产品时就能看到产品秘钥(ProductSecret)了,并且要确保打开了动态注册,如下图所示。
6.2.2 代码使用说明
1. 设备注册并进行连接云平台
记得修改参数
sys.taskInit(function()
-- 等待联网
local ret, device_id = sys.waitUntil("net_ready")
-------- 以下接入方式根据自己需要修改,相关参数修改为自己的 ---------
-- 阿里云
-- 动态注册(免预注册)(一型一密)(仅企业版支持)
iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",product_secret = "xxx"}) -- 企业版公共实例
-- 动态注册(预注册)(一型一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 新版公共实例
-- 密钥校验 (预注册)(一机一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",device_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",device_secret = "xxx"})-- 新版公共实例
if iotcloudc then
iotcloudc:connect()
end
end)
2. 每隔 2 秒发布一次 qos 为 1 的消息到云平台
本文
iotcloudc:publish()
中的第一个参数订阅的是一个自定义 topic,在阿里云物联网平台上可以看到。用户可以根据需求自行修改第一个参数。
-- 每隔2秒发布一次qos为1的消息到云平台
sys.taskInit(function()
while 1 do
sys.wait(2000)
if iotcloudc then
iotcloudc:publish("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/update", "hello world", 1) -- 上传数据
end
end
end)
3. 订阅主题,用于云平台下发消息
此行代码放置位置,只要在云平台连接成功之后即可,可参考后面的 4.接收数据 本文
iotcloudc:subscribe()
中的第一个参数订阅的仍然是一个自定义 topic 订阅成功之后,在阿里云物联网平台会有显示,看下图
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
4. 接收数据
接收统一使用了
"iotcloud"
消息进行通知,所以我们只需要订阅此系统消息即可
sys.subscribe("iotcloud", function(cloudc,event,data,payload)
-- 注意,此处不是协程内,复杂操作发消息给协程内进行处理
if event == iotcloud.CONNECT then -- 云平台联上了
print("iotcloud","CONNECT", "云平台连接成功")
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
elseif event == iotcloud.RECEIVE then
print("iotcloud","topic", data, "payload", payload)
-- 用户处理代码
elseif event == iotcloud.OTA then
if data then
rtos.reboot()
end
elseif event == iotcloud.DISCONNECT then -- 云平台断开了
-- 用户处理代码
end
end)
5. 完整代码
注意,记得修改参数!!!
-- LuaTools需要PROJECT和VERSION这两个信息
PROJECT = "aliyun_yxym_myzc"
VERSION = "1.0.0"
-- sys库是标配
_G.sys = require("sys")
--[[特别注意, 使用mqtt库需要下列语句]]
_G.sysplus = require("sysplus")
local iotcloud = require("iotcloud")
-- Air780E的AT固件默认会为开机键防抖, 导致部分用户刷机很麻烦
if rtos.bsp() == "EC618" and pm and pm.PWK_MODE then
pm.power(pm.PWK_MODE, false)
end
-- 统一联网函数
sys.taskInit(function()
local device_id = mcu.unique_id():toHex()
-----------------------------
-- 统一联网函数, 可自行删减
----------------------------
if wlan and wlan.connect then
-- wifi 联网, ESP32系列均支持
local ssid = "luatos1234"
local password = "12341234"
log.info("wifi", ssid, password)
-- TODO 改成自动配网
-- LED = gpio.setup(12, 0, gpio.PULLUP)
wlan.init()
wlan.setMode(wlan.STATION) -- 默认也是这个模式,不调用也可以
device_id = wlan.getMac()
wlan.connect(ssid, password, 1)
elseif mobile then
-- Air780E/Air600E系列
--mobile.simid(2) -- 自动切换SIM卡
-- LED = gpio.setup(27, 0, gpio.PULLUP)
device_id = mobile.imei()
elseif w5500 then
-- w5500 以太网, 当前仅Air105支持
w5500.init(spi.HSPI_0, 24000000, pin.PC14, pin.PC01, pin.PC00)
w5500.config() --默认是DHCP模式
w5500.bind(socket.ETH0)
-- LED = gpio.setup(62, 0, gpio.PULLUP)
elseif socket or mqtt then
-- 适配的socket库也OK
-- 没有其他操作, 单纯给个注释说明
else
-- 其他不认识的bsp, 循环提示一下吧
while 1 do
sys.wait(1000)
log.info("bsp", "本bsp可能未适配网络层, 请查证")
end
end
-- 默认都等到联网成功
sys.waitUntil("IP_READY")
sys.publish("net_ready", device_id)
end)
sys.taskInit(function()
-- 等待联网
local ret, device_id = sys.waitUntil("net_ready")
-------- 以下接入方式根据自己需要修改,相关参数修改为自己的 ---------
-- 阿里云
-- 动态注册(免预注册)(一型一密)(仅企业版支持)
iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",product_secret = "xxx"}) -- 企业版公共实例
-- 动态注册(预注册)(一型一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 新版公共实例
-- 密钥校验 (预注册)(一机一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",device_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",device_secret = "xxx"})-- 新版公共实例
if iotcloudc then
iotcloudc:connect()
end
end)
sys.subscribe("iotcloud", function(cloudc,event,data,payload)
-- 注意,此处不是协程内,复杂操作发消息给协程内进行处理
if event == iotcloud.CONNECT then -- 云平台联上了
print("iotcloud","CONNECT", "云平台连接成功")
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
elseif event == iotcloud.RECEIVE then
print("iotcloud","topic", data, "payload", payload)
-- 用户处理代码
elseif event == iotcloud.OTA then
if data then
rtos.reboot()
end
elseif event == iotcloud.DISCONNECT then -- 云平台断开了
-- 用户处理代码
end
end)
-- 每隔2秒发布一次qos为1的消息到云平台
sys.taskInit(function()
while 1 do
sys.wait(2000)
if iotcloudc then
iotcloudc:publish("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/update", "hello world", 1) -- 上传数据
end
end
end)
-- 用户代码已结束---------------------------------------------
-- 结尾总是这一句
sys.run()
-- sys.run()之后后面不要加任何语句!!!!!
6.2.3 运行结果展示
1. 设备日志
2. 云平台效果
3. 上行数据效果
4. 下发数据效果
通过 Luatools 工具查看日志即可
发布消息:
接收消息:
6.3 一型一密(预注册)方式连接云平台
此方式也极为简单,与一型一密(免预注册)的区别就是需要用户手动注册设备,建议用户注册设备时使用模组的 IMEI 号作为设备名进行注册。它同样也需要三个参数,实例 ID,产品 ID(ProjectKey)和产品秘钥(ProductSecret)。
6.3.1 手动注册设备
建议用户注册设备时使用模组的 IMEI 号作为设备名进行注册。
6.3.2 获取需要的三个参数
实例 ID 和产品 ID(ProjectKey)在上面准备阶段的时候已经拿到了,接下来我们查看产品时就能看到产品秘钥(ProductSecret)了,此时动态注册可以不用开启,只是免预注册方式时需要开启。
6.3.3 代码使用说明
1. 设备注册并进行连接云平台
记得修改参数
sys.taskInit(function()
-- 等待联网
local ret, device_id = sys.waitUntil("net_ready")
-------- 以下接入方式根据自己需要修改,相关参数修改为自己的 ---------
-- 阿里云
-- 动态注册(免预注册)(一型一密)(仅企业版支持)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",product_secret = "xxx"}) -- 企业版公共实例
-- 动态注册(预注册)(一型一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 旧版公共实例
iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 新版公共实例
-- 密钥校验 (预注册)(一机一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",device_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",device_secret = "xxx"})-- 新版公共实例
if iotcloudc then
iotcloudc:connect()
end
end)
2. 每隔 2 秒发布一次 qos 为 1 的消息到云平台
本文
iotcloudc:publish()
中的第一个参数订阅的是一个自定义 topic,在阿里云物联网平台上可以看到。用户可以根据需求自行修改第一个参数。
-- 每隔2秒发布一次qos为1的消息到云平台
sys.taskInit(function()
while 1 do
sys.wait(2000)
if iotcloudc then
iotcloudc:publish("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/update", "hello world", 1) -- 上传数据
end
end
end)
3. 订阅主题,用于云平台下发消息
此行代码放置位置,只要在云平台连接成功之后即可,可参考后面的 4.接收数据 本文
iotcloudc:subscribe()
中的第一个参数订阅的仍然是一个自定义 topic 订阅成功之后,在阿里云物联网平台会有显示,看下图
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
4. 接收数据
接收统一使用了
"iotcloud"
消息进行通知,所以我们只需要订阅此系统消息即可
sys.subscribe("iotcloud", function(cloudc,event,data,payload)
-- 注意,此处不是协程内,复杂操作发消息给协程内进行处理
if event == iotcloud.CONNECT then -- 云平台联上了
print("iotcloud","CONNECT", "云平台连接成功")
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
elseif event == iotcloud.RECEIVE then
print("iotcloud","topic", data, "payload", payload)
-- 用户处理代码
elseif event == iotcloud.OTA then
if data then
rtos.reboot()
end
elseif event == iotcloud.DISCONNECT then -- 云平台断开了
-- 用户处理代码
end
end)
5. 完整代码
注意,记得修改参数!!!
-- LuaTools需要PROJECT和VERSION这两个信息
PROJECT = "aliyun_yxym_yzc"
VERSION = "1.0.0"
-- sys库是标配
_G.sys = require("sys")
--[[特别注意, 使用mqtt库需要下列语句]]
_G.sysplus = require("sysplus")
local iotcloud = require("iotcloud")
-- Air780E的AT固件默认会为开机键防抖, 导致部分用户刷机很麻烦
if rtos.bsp() == "EC618" and pm and pm.PWK_MODE then
pm.power(pm.PWK_MODE, false)
end
-- 统一联网函数
sys.taskInit(function()
local device_id = mcu.unique_id():toHex()
-----------------------------
-- 统一联网函数, 可自行删减
----------------------------
if wlan and wlan.connect then
-- wifi 联网, ESP32系列均支持
local ssid = "luatos1234"
local password = "12341234"
log.info("wifi", ssid, password)
-- TODO 改成自动配网
-- LED = gpio.setup(12, 0, gpio.PULLUP)
wlan.init()
wlan.setMode(wlan.STATION) -- 默认也是这个模式,不调用也可以
device_id = wlan.getMac()
wlan.connect(ssid, password, 1)
elseif mobile then
-- Air780E/Air600E系列
--mobile.simid(2) -- 自动切换SIM卡
-- LED = gpio.setup(27, 0, gpio.PULLUP)
device_id = mobile.imei()
elseif w5500 then
-- w5500 以太网, 当前仅Air105支持
w5500.init(spi.HSPI_0, 24000000, pin.PC14, pin.PC01, pin.PC00)
w5500.config() --默认是DHCP模式
w5500.bind(socket.ETH0)
-- LED = gpio.setup(62, 0, gpio.PULLUP)
elseif socket or mqtt then
-- 适配的socket库也OK
-- 没有其他操作, 单纯给个注释说明
else
-- 其他不认识的bsp, 循环提示一下吧
while 1 do
sys.wait(1000)
log.info("bsp", "本bsp可能未适配网络层, 请查证")
end
end
-- 默认都等到联网成功
sys.waitUntil("IP_READY")
sys.publish("net_ready", device_id)
end)
sys.taskInit(function()
-- 等待联网
local ret, device_id = sys.waitUntil("net_ready")
-------- 以下接入方式根据自己需要修改,相关参数修改为自己的 ---------
-- 阿里云
-- 动态注册(免预注册)(一型一密)(仅企业版支持)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",product_secret = "xxx"}) -- 企业版公共实例
-- 动态注册(预注册)(一型一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 旧版公共实例
iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 新版公共实例
-- 密钥校验 (预注册)(一机一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",device_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",device_secret = "xxx"})-- 新版公共实例
if iotcloudc then
iotcloudc:connect()
end
end)
sys.subscribe("iotcloud", function(cloudc,event,data,payload)
-- 注意,此处不是协程内,复杂操作发消息给协程内进行处理
if event == iotcloud.CONNECT then -- 云平台联上了
print("iotcloud","CONNECT", "云平台连接成功")
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
elseif event == iotcloud.RECEIVE then
print("iotcloud","topic", data, "payload", payload)
-- 用户处理代码
elseif event == iotcloud.OTA then
if data then
rtos.reboot()
end
elseif event == iotcloud.DISCONNECT then -- 云平台断开了
-- 用户处理代码
end
end)
-- 每隔2秒发布一次qos为1的消息到云平台
sys.taskInit(function()
while 1 do
sys.wait(2000)
if iotcloudc then
iotcloudc:publish("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/update", "hello world", 1) -- 上传数据
end
end
end)
-- 用户代码已结束---------------------------------------------
-- 结尾总是这一句
sys.run()
-- sys.run()之后后面不要加任何语句!!!!!
6.3.4 运行结果展示
1. 设备日志
2. 云平台效果
3. 上行数据效果
4. 下发数据效果
通过 Luatools 工具查看日志即可
发布消息:
接收消息:
6.4 一机一密方式连接云平台
此方式与一型一密(预注册)一样需要用户手动注册设备,区别在于此时所需要的三个参数为产品 ID(ProjectKey)、产品名称和产品秘钥(ProductSecret)。
需要注意,如果是新版公共实例,则需要在原有的三个参数基础上再多个实例 ID,因此需要四个参数。
6.4.1 手动注册设备
建议用户注册设备时使用模组的 IMEI 号作为设备名进行注册。
6.4.2 获取需要的三/四个参数
旧版公共实例需要三个参数:产品 ID(ProjectKey)、产品名称和产品秘钥(ProductSecret)。
新版公共实例需要四个参数:产品 ID(ProjectKey)、产品名称、产品秘钥(ProductSecret)和实例 ID 。
6.4.3 代码使用说明
1. 设备注册并进行连接云平台
记得修改参数
sys.taskInit(function()
-- 等待联网
local ret, device_id = sys.waitUntil("net_ready")
-------- 以下接入方式根据自己需要修改,相关参数修改为自己的 ---------
-- 阿里云
-- 动态注册(免预注册)(一型一密)(仅企业版支持)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",product_secret = "xxx"}) -- 企业版公共实例
-- 动态注册(预注册)(一型一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 新版公共实例
-- 密钥校验 (预注册)(一机一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",device_secret = "xxx"}) -- 旧版公共实例
iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",device_secret = "xxx"})-- 新版公共实例
if iotcloudc then
iotcloudc:connect()
end
end)
2. 每隔 2 秒发布一次 qos 为 1 的消息到云平台
本文
iotcloudc:publish()
中的第一个参数订阅的是一个自定义 topic,在阿里云物联网平台上可以看到。用户可以根据需求自行修改第一个参数。
-- 每隔2秒发布一次qos为1的消息到云平台
sys.taskInit(function()
while 1 do
sys.wait(2000)
if iotcloudc then
iotcloudc:publish("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/update", "hello world", 1) -- 上传数据
end
end
end)
3. 订阅主题,用于云平台下发消息
此行代码放置位置,只要在云平台连接成功之后即可,可参考后面的 4.接收数据 本文
iotcloudc:subscribe()
中的第一个参数订阅的仍然是一个自定义 topic 订阅成功之后,在阿里云物联网平台会有显示,看下图
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
4. 接收数据
接收统一使用了
"iotcloud"
消息进行通知,所以我们只需要订阅此系统消息即可
sys.subscribe("iotcloud", function(cloudc,event,data,payload)
-- 注意,此处不是协程内,复杂操作发消息给协程内进行处理
if event == iotcloud.CONNECT then -- 云平台联上了
print("iotcloud","CONNECT", "云平台连接成功")
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
elseif event == iotcloud.RECEIVE then
print("iotcloud","topic", data, "payload", payload)
-- 用户处理代码
elseif event == iotcloud.OTA then
if data then
rtos.reboot()
end
elseif event == iotcloud.DISCONNECT then -- 云平台断开了
-- 用户处理代码
end
end)
5. 完整代码
注意,记得修改参数!!!
-- LuaTools需要PROJECT和VERSION这两个信息
PROJECT = "aliyun_yjym_yzc"
VERSION = "1.0.0"
-- sys库是标配
_G.sys = require("sys")
--[[特别注意, 使用mqtt库需要下列语句]]
_G.sysplus = require("sysplus")
local iotcloud = require("iotcloud")
-- Air780E的AT固件默认会为开机键防抖, 导致部分用户刷机很麻烦
if rtos.bsp() == "EC618" and pm and pm.PWK_MODE then
pm.power(pm.PWK_MODE, false)
end
-- 统一联网函数
sys.taskInit(function()
local device_id = mcu.unique_id():toHex()
-----------------------------
-- 统一联网函数, 可自行删减
----------------------------
if wlan and wlan.connect then
-- wifi 联网, ESP32系列均支持
local ssid = "luatos1234"
local password = "12341234"
log.info("wifi", ssid, password)
-- TODO 改成自动配网
-- LED = gpio.setup(12, 0, gpio.PULLUP)
wlan.init()
wlan.setMode(wlan.STATION) -- 默认也是这个模式,不调用也可以
device_id = wlan.getMac()
wlan.connect(ssid, password, 1)
elseif mobile then
-- Air780E/Air600E系列
--mobile.simid(2) -- 自动切换SIM卡
-- LED = gpio.setup(27, 0, gpio.PULLUP)
device_id = mobile.imei()
elseif w5500 then
-- w5500 以太网, 当前仅Air105支持
w5500.init(spi.HSPI_0, 24000000, pin.PC14, pin.PC01, pin.PC00)
w5500.config() --默认是DHCP模式
w5500.bind(socket.ETH0)
-- LED = gpio.setup(62, 0, gpio.PULLUP)
elseif socket or mqtt then
-- 适配的socket库也OK
-- 没有其他操作, 单纯给个注释说明
else
-- 其他不认识的bsp, 循环提示一下吧
while 1 do
sys.wait(1000)
log.info("bsp", "本bsp可能未适配网络层, 请查证")
end
end
-- 默认都等到联网成功
sys.waitUntil("IP_READY")
sys.publish("net_ready", device_id)
end)
sys.taskInit(function()
-- 等待联网
local ret, device_id = sys.waitUntil("net_ready")
-------- 以下接入方式根据自己需要修改,相关参数修改为自己的 ---------
-- 阿里云
-- 动态注册(免预注册)(一型一密)(仅企业版支持)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",product_secret = "xxx"}) -- 企业版公共实例
-- 动态注册(预注册)(一型一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 旧版公共实例
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",product_secret = "xxx"}) -- 新版公共实例
-- 密钥校验 (预注册)(一机一密)
-- iotcloudc = iotcloud.new(iotcloud.ALIYUN,{produt_id = "xxx",device_name = "xxx",key = "xxx"}) -- 旧版公共实例
iotcloudc = iotcloud.new(iotcloud.ALIYUN,{instance_id = "xxx",produt_id = "xxx",device_name = "xxx",key = "xxx"})-- 新版公共实例
if iotcloudc then
iotcloudc:connect()
end
end)
sys.subscribe("iotcloud", function(cloudc,event,data,payload)
-- 注意,此处不是协程内,复杂操作发消息给协程内进行处理
if event == iotcloud.CONNECT then -- 云平台联上了
print("iotcloud","CONNECT", "云平台连接成功")
iotcloudc:subscribe("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/get") -- 订阅主题,用于下发消息
elseif event == iotcloud.RECEIVE then
print("iotcloud","topic", data, "payload", payload)
-- 用户处理代码
elseif event == iotcloud.OTA then
if data then
rtos.reboot()
end
elseif event == iotcloud.DISCONNECT then -- 云平台断开了
-- 用户处理代码
end
end)
-- 每隔2秒发布一次qos为1的消息到云平台
sys.taskInit(function()
while 1 do
sys.wait(2000)
if iotcloudc then
iotcloudc:publish("/"..iotcloudc.product_id.."/"..iotcloudc.device_name.."/user/update", "hello world", 1) -- 上传数据
end
end
end)
-- 用户代码已结束---------------------------------------------
-- 结尾总是这一句
sys.run()
-- sys.run()之后后面不要加任何语句!!!!!
6.4.4 运行结果展示
1. 设备日志
2. 云平台效果
3. 上行数据效果
4. 下发数据效果
通过 Luatools 工具查看日志即可
发布消息:
接收消息:
6.5 阿里云 OTA 升级
6.5.1 建立项目并连接阿里云
根据前面的操作说明,实现阿里云连接。
6.5.2 制作差分升级文件包
6.5.2.1 熟悉 Luatools 工具
在制作差分升级文件包之前,请先熟悉如何使用 Luatools 工具:Luatools 下载和详细使用
6.5.2.2 制作差分包
本次 demo 以一型一密(预注册)的 demo 为例。 同时需要注意,Luatools 工具要使用 2.1.89 以上的版本
1. 只升级脚本,差分包制作流程如下:
需要注意,升级前的脚本版本号 < 升级后的脚本版本号,而且我们此时模块中烧录的是升级前的脚本,不要搞错了。
固件及 demo 到前面的 源码及固件 章节下载,下载完成后根据下方图片进行操作,生成量产文件。
在选择的保存路径下会自动生成 SOC 量产及远程升级文件\Air201 文件夹,下图中箭头位置即为我们需要的差分包文件。
2. 需要升级底层 CORE,差分包制作流程如下:
需要注意,升级前的固件版本号 <= 升级后的固件版本号
a. 生成新固件版本的量产固件
b. 根据新旧固件生成差分包
6.5.3 阿里云平台上传差分包
注意,如果在上传差分包时出现错误,需要把差分包文件名缩短长度
6.5.4 升级包验证
点完确定之后,如果模块此时初始开机状态,会自动进行升级操作,期间会自动重启属于正常现象。
6.5.5 升级完成
1. 设备日志
2. 云平台效果
七、总结
本文详细介绍了如何使用 Air201模组和阿里云物联网平台实现物联网设备的连接与管理。首先,我们准备了必要的硬件环境,包括 Air201模组、SIM 卡、PC 电脑和数据通信线。接着,我们配置了软件环境,包括 Luatools 下载调试工具和阿里云物联网平台。
在连接阿里云物联网平台的过程中,我们创建了产品,配置了认证方式,并在 Air201模组上编写了代码以实现与阿里云物联网平台的连接。我们展示了如何通过编写代码,使 Air201模组每隔一定时间向阿里云物联网平台上传数据,并在平台上创建消息主题以接收 Air201模组发送的数据。
我们还展示了如何创建消息主题以向 Air201模组下发消息,并实现订阅云端下发的消息。通过 Luatools 工具和阿里云物联网平台,我们验证了数据的上传和接收,以及下发消息的效果。
通过本文的学习,大家可以掌握如何使用 Air201模组和阿里云物联网平台实现物联网设备的连接与管理。
八、扩展
8.1 MQTT 通信协议 QoS 介绍
MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,它设计用于低带宽和不稳定的网络环境。MQTT 协议专注于设备连接的稳定性和网络的优化使用,特别适合于物联网(IoT)场景。
在 MQTT 中,消息的传输质量是通过 QoS(Quality of Service,服务质量)等级来定义的。QoS 定义了消息的传递可靠性,共有三个等级:
1. QoS 0(最多传递一次):
-
最多传递一次:消息可能会丢失。
-
适用于非关键数据,或者允许数据丢失的场景。
2. QoS 1(至少传递一次):
-
至少传递一次:确保消息至少从发布者传输到服务器,并且至少传递给每个订阅者一次。
-
如果传输过程中出现错误,客户端会重新发送消息。
-
适用于需要确认数据已传输但可以容忍一定程度数据丢失的场景。
3. QoS 2(确保传递一次):
-
确保传递一次:确保消息从发布者传输到服务器,并且只传递给每个订阅者一次,而且在传输过程中不会被重复传递。
-
客户端会在消息确认之后才能接收到下一个消息。
-
适用于对数据可靠性要求极高的场景,如关键数据传输。
选择适当的 QoS 级别取决于应用场景对数据可靠性和网络资源利用的要求。在设计物联网应用时,通常需要根据设备的能力、网络条件以及应用的容忍度来选择合适的 QoS 设置。
九、常见问题
1. 如何实现数据的上传和接收?
数据的上传和接收是通过订阅和发布消息实现的。在代码中,需要调用
iotcloudc:publish()
和iotcloudc:subscribe()
方法,分别用于发布和订阅消息。