ESP8266連接阿里云物聯(lián)網平臺(Arduino方式)
掃描二維碼
隨時隨地手機看文章
我們上一篇網文已經介紹了mini D1 WiFi模塊,具體參見下面鏈接:
下面網文介紹了如何在阿里云生活物聯(lián)網平臺創(chuàng)建一個智能設備:
本文我們利用之前創(chuàng)建的測試設備的三元組信息:
"product_key": "a1xHkDRtfRl",
"device_name": "ZNFS0001",
"device_secret": "xnOe5VcOkvXFTBAZaik4hz7y67t7IUhI"
使用Arduino的方式快速連接阿里云物聯(lián)網平臺。
文中提到的 AliyunIoTSDK 這個 Arduino 庫,可以在 Arduino 庫商店里搜索到(搜索 AliyunIoTSDK)


AliyunIoTSDK可以幫助你快速連接阿里云 IoT 平臺,通過和阿里云物聯(lián)網開發(fā)平臺配合,可快速實現各種硬件應用,包括了很上層的封裝,無需自己解析數據體,綁定事件即可,在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庫

再次編譯仍舊報錯:

錯誤信息如下所示:
Arduino:1.8.8 (Windows 10), 開發(fā)板:"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^ compilation terminated. exit status 1 為開發(fā)板 WeMos D1 R1 編譯時出錯。 在文件 -> 首選項開啟 “編譯過程中顯示詳細輸出”選項 這份報告會包含更多信息。
因為AliyunIoTSDK庫,底層連接依據 PubSubClient 庫,所以繼續(xù)安裝:PubSubClient庫。

缺少:SHA256庫,繼續(xù)安裝:SHA256庫


“AWS-SDK-ESP8266”庫。

再次編譯,成功。

編譯并下載程序,上傳固件至mini D1 WiFi模塊。

上傳成功之后顯示如下:

arduino上阿里云所需要用到的四個庫文件。PubSubClient,ArduinoJson,AliyunIoTSDK,Crypto(SHA256)。
PubSubClient.h,是發(fā)布/訂閱功能的頭文件;
SHA256.h,是加密功能的頭文件(Crypto里面已有包含這個了);
ArduinoJson.h,是支持Json數據格式的頭文件;
AliyunIoTSDK.h,是阿里云SDK的頭文件。
打開Arduino軟件,工具-->串口監(jiān)視器,可以查看模塊打印輸出的信息:

這個串口號換了,不是上面的COM7了,因為我更換了USB口,所以串口號變化了。
下面是在PubSubClient.h文件中關于錯誤類型的定義:

報錯MQTT Connect err : -2,說明MQTT沒有連接。
解決方法是更改PubSubClient.h文件中的兩個宏MQTT_MAX_PACKET_SIZE和MQTT_KEEPALIVE,將其改大點,比如改成1024和60。


修改后,重新下載程序,然后看到可以正常上傳數據了。

登錄生活物聯(lián)網平臺--飛燕平臺
生活物聯(lián)網平臺:https://living.aliyun.com/#/
查看飛燕平臺,正常應該可以看到設備上線了。

點擊上圖中設備右邊的“查看”,然后進入下面的運行狀態(tài)頁面,可以看到我們上傳的當前溫度:26℃。

與下面我們代碼中設置的值是一致的,進而說明上傳屬性值成功。
在“設備調試”頁面,我們選擇調試設備為“ZNFS0001”,然后選擇一個調試功能,然后選擇方法,然后點擊發(fā)送指令,我們可以在實時日志中查看到下發(fā)數據的日志,說明下發(fā)數據成功。

此時查看WiFi模塊的打印信息,可以看到模塊收到了服務器下發(fā)的數據包。
{"method":"thing.service.property.set","id":"2028064192","params":{"PowerSwitch":0},"version":"1.0.0"}

我們只需要能夠正確解析上面的數據包內容,解析出{"PowerSwitch":0},然后單片機就可以針對此內容做相應的動作。
上面“設備調試”中下發(fā)的數據,其實過程跟手機App中點擊某個的按鈕的動作邏輯是一樣的,至此走通了設備屬性的上傳及設備的無線控制。
之后的內容,我們將針對“智能風扇”的具體設計,實現STM32+ESP8266整體與阿里云進行數據交互。
完整代碼如下:
// 引入 wifi 模塊,并實例化,不同的芯片這里的依賴可能不同 #includestatic WiFiClient espClient; // 引入阿里云 IoT SDK #include // 設置產品和設備的信息,從阿里云設備信息里查看 #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); // 綁定一個設備屬性回調,當遠程修改此屬性,會觸發(fā) powerCallback // PowerSwitch 是在設備產品中定義的物聯(lián)網模型的 id AliyunIoTSDK::bindData("PowerSwitch", powerCallback); // 發(fā)送一個數據到云平臺,CurrentTemperature 是在設備產品中定義的物聯(lián)網模型的 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) { // 啟動設備 } }