【ESP32】Lua + ESP32C3 + DHT11温湿度传感器的数据实时上传到阿里云。

本文主要是介绍【ESP32】Lua + ESP32C3 + DHT11温湿度传感器的数据实时上传到阿里云。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


前言

用lua,ESP32C3 + DHT11温湿度传感器的数据实时上传到阿里云。
就这么件事儿。
用Lua是因为代码会简单一些。
废话不多讲,下面开始。


一、合宙ESP32C3经典版

ESP32C3经典版开发板,9.9元一个,淘宝有卖的,自带BLE和WIFI模块,能跑RTOS,用来练习真不错,价格也比较亲民。
在这里插入图片描述

ESP32C3的开发平台有很多,目前主流的平台基本都兼容,Arduino,VScode-IOplatform,VScode-Espressif,Espressif-IDE等等等等。

我这里用的是VScode进行编码,Luatools进行烧写,不知你们有没有感觉,每次在等VS烧写的时候,都不敢碰VS里的代码,好像多看一眼就会爆炸(bushi)。个人感觉Luatools能快一些(幻觉)。
在这里插入图片描述

上述所有的开发环境的搭建方法论坛里有很多义父级的教程,我就不多赘述了,自己去搜。

这里贴一个合宙官方的介绍作为参考:
ESP32C3-CORE开发板

二、阿里云

我用的是阿里云,它是一个免费好用的物联网平台,选择它你的项目就已经完成了50%。
(其实是因为我的Onenet不知因为啥上不去了。。T ^ T’‘’)

云平台的搭建流程嘛,大同小异,各大商家已经尽量简化操作流程了,
基本都是创建产品→添加设备→添加数据流。
具体的方法与过程嘛,论坛里的众多义父也都有教程。
总之,以阿里云为例,平台搭建完成需要以下信息,分别是你产品的MQTT三元参数,和你设备证书。
一定要保存下来,后边编码的时候会用到。
在这里插入图片描述

在这里插入图片描述

三、Lua

“Lua是一种轻量级的、可嵌入的脚本语言,广泛应用于嵌入式系统、游戏开发、Web开发和其他领域。它具有简洁的语法、高效的执行速度和灵活的扩展性,被认为是一种简单而强大的脚本语言…”----ChatGPT.

官方的介绍很官方,我总结一下Lua原因就三点:
1.比较简单
2.可移植性强
3.库多
这也可以说是所有流行语言特性的最大公约数了。

由于是要用Lua语言写,所以需要参考Lua基本语法和一些API
↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

→Lua基础语法
→LuatOS-SOC接口文档

四、完整代码

明白了基本语法和API的用法后,
像这样抽5分钟随随便便写几行代码,然后去庙里烧三天香就OK了。
你要改的只是上面这些local定义而已。


--LuaTools需要PROJECT和VERSION这两个信息,这里不要动
PROJECT = "mqttdemo"
VERSION = "1.0.0"--配置Wi-Fi和MQTT连接参数--wifi_ssid:你的wifi名--wifi_password:你的wifi密码--mqtt_broker:你的阿里云提供的mqttHostUrl--端口,阿里云默认1883,这个不用改
local wifi_ssid = "zhixue"  
local wifi_password = "zx888888"    
local mqtt_broker = "iot-06z00haxv1im9qy.mqtt.iothub.aliyuncs.com" 
local mqtt_port = 1883  --阿里云三元参数 clientId/ username/ passwd
local mqtt_clientid = "k068w8H1iZ5.dht11|securemode=2,signmethod=hmacsha256,timestamp=1694677026850|"
local mqtt_username = "dht11&k068w8H1iZ5"
local mqtt_password = "1bc68386a98c8786389ab83544a47db22f9d986534b6fc6cda7330f513999d7b"--Topic设置,要与云端保持一致
--这个要注意下格式
--格式为:"/sys/你的ProductKey/你的DeviceName/thing/event/property/post"--例如:--我的ProductKey是k068w8H1iZ5--我的DeviceName是dht11
--分别填入,则得到下面的mqtt_topic
--↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
local mqtt_topic = "/sys/k068w8H1iZ5/dht11/thing/event/property/post"-- DHT11连接到GPIO7,随你高兴
local dht_pin = 7 -- 连接Wi-Fi网络
wifi.setmode(wifi.STATION)
wifi.sta.config(wifi_ssid, wifi_password)
wifi.sta.connect()-- 等待Wi-Fi连接成功
while wifi.sta.getip() == nil dotmr.delay(1000)print("Connecting with wifi "..wifi_ssid)
endprint("Wi-Fi connected. IP address: " .. wifi.sta.getip())-- 连接MQTT服务器
local mqtt_client = mqtt.client(mqtt_broker, mqtt_port, mqtt_clientid, mqtt_username, mqtt_password)-- 处理MQTT连接事件
mqtt_client:on("connect", function(client)print("MQTT connected to " .. mqtt_broker .. ":" .. mqtt_port)
end)mqtt_client:on("offline", function(client)print("MQTT disconnected")-- 在断开连接后重新连接mqtt_client:connect()
end)-- 连接DHT11传感器
-- 定时读取传感器数据并发布到MQTT
-- 注意发送的数据名与云端的数据标识符保持一致
tmr.create():alarm(5000, tmr.ALARM_AUTO, function()local wendu, shidu, status = sensor.dht1x(dht_pin)if status == true thenlocal payload = "wendu: " .. wendu .. "°C, Humidity: " .. shidu .. "%"mqtt_client:publish(mqtt_topic, payload)print("Published: " .. payload)elseprint("DHT11 read error")end
end)

五、云端验证

用Luatools烧录之后,板子自动连接至预设的云端,并实时上传温湿度数据。
在这里插入图片描述
喏,这样就成功了。

总结

代码都给你了没啥总结的,这自习室蚊子太多,我受不了了我先溜了。

这篇关于【ESP32】Lua + ESP32C3 + DHT11温湿度传感器的数据实时上传到阿里云。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/467417

相关文章

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解