使用Arduino的方式快速连接阿里云物联网平台。
文中提到的 AliyunIoTSDK 这个 Arduino 库,可以在 Arduino 库商店里搜索到(搜索 AliyunIoTSDK)
AliyunIoTSDK可以帮助你快速连接阿里云 IoT 平台,通过和阿里云物联网开发平台配合,可快速实现各种硬件应用,包括了很上层的封装,无需自己解析数据体,绑定事件即可,在ESP8266平台充分测试(NodeMCU 1.0)
AliyunIoTSDK库,除了上面在Arduino库商店里直接搜索外,还可以手动把 github 上的项目 clone 下来,放到 Arduino 的 library 库下。
github 地址:https://github.com/xinyu198736/arduino-aliyun-iot-sdk
拷贝上面网址上的测试代码:Usage使用示例
随意命名文件名,保存代码文件:
设备管理器中查看当前ESP8266 WiFi所占用的串口号:
Arduino中选择对应的串口号:
填写三元组和WiFi信息:
点击“√”对号对工程进行编译:
编译后出错:
添加:ArduinoJson库
再次编译仍旧报错:
错误信息如下所示:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | Arduino:1.8.8 (Windows 10), 开发板:"WeMos D1 R1, 80 MHz, Flash, Legacy (new can return nullptr), All SSL ciphers (most compatible), 4MB (FS:2MB OTA:~1019KB), v2 Lower Memory, Disabled, None, Only Sketch, 115200" 构建选项已变更,全部重新构建 C:\Users\juban\Documents\Arduino\libraries\AliyunIoTSDK\src\AliyunIoTSDK.cpp:3:26: fatal error: PubSubClient.h: No such file or directory #include <PubSubClient.h> ^ compilation terminated. exit status 1 为开发板 WeMos D1 R1 编译时出错。 在文件 -> 首选项开启 “编译过程中显示详细输出”选项 这份报告会包含更多信息。 |
因为AliyunIoTSDK库,底层连接依据 PubSubClient 库,所以继续安装:PubSubClient库。
缺少:SHA256库,继续安装:SHA256库
“AWS-SDK-ESP8266”库。
再次编译,成功。
编译并下载程序,上传固件至mini D1 WiFi模块。
上传成功之后显示如下:
arduino上阿里云所需要用到的四个库文件。PubSubClient,ArduinoJson,AliyunIoTSDK,Crypto(SHA256)。
PubSubClient.h,是发布/订阅功能的头文件;
SHA256.h,是加密功能的头文件(Crypto里面已有包含这个了);
ArduinoJson.h,是支持Json数据格式的头文件;
AliyunIoTSDK.h,是阿里云SDK的头文件。
打开Arduino软件,工具-->串口监视器,可以查看模块打印输出的信息:
这个串口号换了,不是上面的COM7了,因为我更换了USB口,所以串口号变化了。
下面是在PubSubClient.h文件中关于错误类型的定义:
报错MQTT Connect err : -2,说明MQTT没有连接。
解决方法是更改PubSubClient.h文件中的两个宏MQTT_MAX_PACKET_SIZE和MQTT_KEEPALIVE,将其改大点,比如改成1024和60。
修改后,重新下载程序,然后看到可以正常上传数据了。
登录生活物联网平台--飞燕平台
生活物联网平台:https://living.aliyun.com/#/
查看飞燕平台,正常应该可以看到设备上线了。
点击上图中设备右边的“查看”,然后进入下面的运行状态页面,可以看到我们上传的当前温度:26℃。
与下面我们代码中设置的值是一致的,进而说明上传属性值成功。
在“设备调试”页面,我们选择调试设备为“ZNFS0001”,然后选择一个调试功能,然后选择方法,然后点击发送指令,我们可以在实时日志中查看到下发数据的日志,说明下发数据成功。
此时查看WiFi模块的打印信息,可以看到模块收到了服务器下发的数据包。
1 | {"method":"thing.service.property.set","id":"2028064192","params":{"PowerSwitch":0},"version":"1.0.0"} |
我们只需要能够正确解析上面的数据包内容,解析出{"PowerSwitch":0},然后单片机就可以针对此内容做相应的动作。
上面“设备调试”中下发的数据,其实过程跟手机App中点击某个的按钮的动作逻辑是一样的,至此走通了设备属性的上传及设备的无线控制。
之后的内容,我们将针对“智能风扇”的具体设计,实现STM32+ESP8266整体与阿里云进行数据交互。
完整代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | // 引入 wifi 模块,并实例化,不同的芯片这里的依赖可能不同 #include <ESP8266WiFi.h> static WiFiClient espClient; // 引入阿里云 IoT SDK #include <AliyunIoTSDK.h> // 设置产品和设备的信息,从阿里云设备信息里查看 #define PRODUCT_KEY "a1xHkDRtfRl" #define DEVICE_NAME "ZNFS0001" #define DEVICE_SECRET "xnOe5VcOkvXFTBAZaik4hz7y67t7IUhI" #define REGION_ID "cn-shanghai" // 设置 wifi 信息 #define WIFI_SSID "XXXXXX" #define WIFI_PASSWD "XXXXXXXX" void setup() { Serial.begin(115200); // 初始化 wifi wifiInit(WIFI_SSID, WIFI_PASSWD); // 初始化 iot,需传入 wifi 的 client,和设备产品信息 AliyunIoTSDK::begin(espClient, PRODUCT_KEY, DEVICE_NAME, DEVICE_SECRET, REGION_ID); // 绑定一个设备属性回调,当远程修改此属性,会触发 powerCallback // PowerSwitch 是在设备产品中定义的物联网模型的 id AliyunIoTSDK::bindData("PowerSwitch", powerCallback); // 发送一个数据到云平台,CurrentTemperature 是在设备产品中定义的物联网模型的 id AliyunIoTSDK::send("CurrentTemperature", 26); } void loop() { AliyunIoTSDK::loop(); } // 初始化 wifi 连接 void wifiInit(const char *ssid, const char *passphrase) { WiFi.mode(WIFI_STA); WiFi.begin(ssid, passphrase); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("WiFi not Connect"); } Serial.println("Connected to AP"); } // 电源属性修改的回调函数 void powerCallback(JsonVariant p) { int PowerSwitch = p["PowerSwitch"]; if (PowerSwitch == 1) { // 启动设备 } } ``` |
点个“在看”表示朕
已阅