ESP8266连接DHT11收集数据上传微信小程序实现实时温湿度监测

ESP8266连接DHT11收集数据上传微信小程序实现实时温湿度监测

一、原理讲解

原理简述:利用发布订阅模式。第一步,先读取DHT11温湿度数值,第二步,新建主题,然后ESP8266往这个主题发送消息,第三步。小程序通过HTTP API接口获取数据。小程序控制原理:ESP8266订阅了一个主题,小程序往这个主题发控制消息,ESP8266就可以收到消息,就可以执行相关控制指令了(开/关函数)

程序讲解:在本示例中,ESP8266 有两个角色,一个是temp(DHT11传感器数据)主题消息的发布者,ESP8266往这个主题推送消息,微信小程序就可以收到传感器数据了。
ESP8266联网后,订阅light主题,手机往这个主题推送消息,ESP8266就能收到手机的控制的指令了。

二、ESP8266连接DHT11读取环境温湿度数据

在这里插入图片描述
本程序是利用arduino IDE开发,关于arduino IDE 的ESP8266环境配置可参考:环境配置: 点击跳转
测试程序:

#include <SimpleDHT.h>
// for DHT11, 
// VCC: 5V or 3V
// GND: GND
// DATA: D4
int pinDHT11 = D4;
SimpleDHT11 dht11(pinDHT11);
void setup() {
  Serial.begin(115200);
}
void loop() {
  // start working...
  Serial.println("=================================");
  Serial.println("Sample DHT11...");
  // read without samples.
  byte temperature = 0;
  byte humidity = 0;
  int err = SimpleDHTErrSuccess;
  if ((err = dht11.read(&temperature, &humidity, NULL)) != SimpleDHTErrSuccess) {
    Serial.print("Read DHT11 failed, err="); Serial.println(err);delay(1000);
    return;
  }
  Serial.print("Sample OK: ");
  Serial.print((int)temperature); Serial.print(" *C, "); 
  Serial.print((int)humidity); Serial.println(" H");
  // DHT11 sampling rate is 1HZ.
  delay(1500);
}

串口窗口:

三、温湿度推送到云端

如果上一步的温湿度可以读取输出,那么就可以在上一步的基础上,把数据上传到云端。

增加了按钮控制,数据用#号包裹,以便app采用字符串切割,分割出来数据,&msg=#23#80#on#\r\n,即#温度#湿度#按钮状态#,app端会根据#号分割字符串进行取值,以便显示。

如果上传的数据不止温湿度,可在#号后面继续添加&msg=#23#80#data1#data2#data3#data4#\r\n,app字符串分割的时候,要根据上传的数据进行分割。

完整版程序:点击下载

需要修改的地方

///@@****************需要修改的地方*****************///
//WIFI名称,区分大小写,不要写错
#define DEFAULT_STASSID  "newhtc"
//WIFI密码
#define DEFAULT_STAPSW "qq123456"
//用户私钥,可在控制台获取,修改为自己的UID
String UID = "7d54f85af42976ee3c2693e692a6bb59";
//主题名字,可在控制台新建
String TOPIC = "temp"; //用于传输温湿度的主题
//DHT11引脚值
int pinDHT11 = D4;  //连接dht11的引脚
//单片机LED引脚值
const int LED_Pin = D2;  //假设连接led的引脚
//主题名字,可在控制台新建
String TOPIC2  = "light002";  //用于led控制的主题
///@@*********************************************///

巴法创客云控制台 新建一个主题,主题名字随意,例如temp,本实例用用temp,使用示例代码时应修改为自己的主题名字,字母或数字或字母加数字组合。UID为用户私钥,在 巴法创客云控制台 注册登陆后可获得。
登陆完成后,可在控制台看到自己的私钥UID,如图所示:
在这里插入图片描述
创建主题,在控制台,可创建主题。

第一输入主题,字母或数字或字母+数字组合。

点击创建主题,要创建两个主题,一个主题用来传递传感器数据,另一个主题用来进行LED灯的控制。在本例程中一个主题名字是:temp ,另一个主题名字是:light,可自定义或修改,不过下方微信小程序里面的主题名字要和ESP8266的主题保持一致,以便正常的往同一个主题发布订阅。
在这里插入图片描述
如果ESP8266连接上网络的话,数据会自动上传,可在巴法创客云控制台 刷新网页,即可看到上传的数据。如下图所示:
在这里插入图片描述
四、微信小程序开发

微信公众平台注册小程序账号,拿到小程序 appid,下面导入项目的时候会用到。

左侧点击 -开发-开发管理-开发设置下方服务器域名处,点击修改,在request合法域名处,添加域名https://api.bemfa.com/ 保存提交即可。如下图。
在这里插入图片描述
在这里插入图片描述
下载安装微信开发者工具。
下载demo示例程序。下载地址: 点击下载

打开微信开发者工具,小程序项目,导入项目。在目录处选择刚刚下载解压的demo示例程序,AppID处填入你的小程序AppID,然后点击下方导入即可。如下图。
在这里插入图片描述
本示例程序非常简单,各位大神可以继续开发添加各种功能,添加背景,优化色彩等等,如果只是简单使用,只需修改/pages/index/index.js 文件中uid 和topic 信息为自己的即可,这里的uid和topic需要和ESP8266填入的uid和topic相同,这里有两个主题,一个用于传输温度和湿度,一个用于控制LED。如下图。
在这里插入图片描述
修改完毕后,ctrl+s 保存修改。可以点击左边屏幕上的按钮进行调试,如下图。
在这里插入图片描述
console控制台可以查看小程序的调试信息。默认每2秒会自动请求一下服务器上的数据,以便查看ESP8266的状态信息。点击打开或者关闭按钮,打开ESP8266串口调试助手,可查看ESP8266是否收到指令,如果第一步ESP8266已联网,都是可以收到信息的。

如果界面和其他功能都开发完毕。可以点击微信开发者工具的上面的上传按钮,如下图。
在这里插入图片描述
上传成功后,再登陆刚刚注册的微信公众平台,在版本管理处,可以看到自己刚刚上传的小程序,提交审核即可,等一天左右,一般都会通过,通过后登陆微信公众平台,提交发布即可。如果是自己使用的,做好加上登陆验证功能,比如验证匹配一下某个字符串是否正确等等,不然小程序上线后别人也可以随意控制了。
在这里插入图片描述

  • 8
    点赞
  • 98
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
智能时代一夜间什么都能远程了。创业者想着如何做智能产品,如何做远程控制。DIY爱好者也想着如何自制各种奇妙的工具。这里和大家一起学习制作一款廉价的智能温湿度计。说它廉价是因为共计花费不过40元,说它智能是因为你可以通过手机微信时时知道该设备所在位置的温湿度。 一、申请微信推送服务 能否实现微信推送服务的平台有很多,这里我就不一一解释了。我选用了「Server酱」,英文名「ServerChan」。你完全可以选用你认为比较好用的平台。「Server酱」的申请方法: 打开该网址https://sc.ftqq.com/3.version,开通并使用: 1.登入:用GitHub账号登入网站,点击进入“发送消息”页面,就能获得一个SCKEY。具体见:https://sc.ftqq.com/?c=code 2.绑定:点击“微信推送”页面,扫码关注同时即可完成绑定 3.发消息:往https://sc.ftqq.com/SCKEY.send发GET请求,就可以在微信里收到消息啦 二、让我们开始DIY温湿度计 1、选择合适的主控板 更喜欢python编程的我,这里选用支持micropython的TPYBoardv202(esp8266)开发板。该开发板能够直接用python进行编程,功能还是比较强大的,甚至可用来作web服务器。这里我们主要是用其进行温湿度传感器的控制及网络请求。 2、DHT11温湿度传感器 DHT11是常用的温湿度传感器,网上可以很轻易就买到。简单的讲,就是可以用这个传感器获取的当前环境的度和湿度。 该传感器使用非常简单,有的有3个引脚,有的有4个引脚。我们在使用时,只用三个,分别为VCC(电源脚,接5V)、DATA(数据引脚)、GND(接地)。 3、正确的连线方法 TPYBoardv202与DHT11的具体接线对应及实物图 TPYBoard v202DHT11传感器 +5vvcc G5DATA GNDGND 三、少不了的编程 TPYBoardv202主要有两个文件来控制,一个是boot,py,一个是main.py。我们只需要修改这两个文件就可以完成程序的编写。两个程序已经附在附件里了,可以免费下载。
1. 硬件准备: - ESP8266开发板 - DHT11温湿度传感器 - 蜂鸣器 - 杜邦线 - 面包板 2. 软件准备: - Arduino IDE - ESP8266库 - DHT库 3. 接线: 将DHT11的VCC接到ESP8266的3.3V,将DHT11的GND接到ESP8266的GND,将DHT11的DATA接到ESP8266的D1口,将蜂鸣器的正极接到ESP8266的D2口,将蜂鸣器的负极接到ESP8266的GND。 4. 代码编写: ``` #include <ESP8266WiFi.h> #include <DHT.h> #define DHTPIN D1 // DHT11 DATA引脚连接ESP8266的D1口 #define DHTTYPE DHT11 // DHT11传感器类型 #define buzzerPin D2 // 蜂鸣器连接ESP8266的D2口 const char* ssid = "你的WiFi名称"; // WiFi名称 const char* password = "你的WiFi密码"; // WiFi密码 DHT dht(DHTPIN, DHTTYPE); void setup() { Serial.begin(9600); pinMode(buzzerPin, OUTPUT); digitalWrite(buzzerPin, HIGH); delay(1000); digitalWrite(buzzerPin, LOW); delay(1000); WiFi.begin(ssid, password); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("Connecting to WiFi..."); } Serial.println("Connected to WiFi"); } void loop() { delay(2000); float h = dht.readHumidity(); // 读取湿度 float t = dht.readTemperature(); // 读取度 if (isnan(h) || isnan(t)) { Serial.println("Failed to read from DHT sensor!"); return; } Serial.print("Humidity: "); Serial.print(h); Serial.print("% Temperature: "); Serial.print(t); Serial.println("°C"); if (t > 28) { // 度超过28°C时触发报警 digitalWrite(buzzerPin, HIGH); delay(1000); digitalWrite(buzzerPin, LOW); delay(1000); } } ``` 5. 上传代码: 将ESP8266通过USB连接到计算机,打开Arduino IDE,选择正确的开发板和端口,将代码上传ESP8266中。 6. 测试: 将DHT11放置在需要检测的环境中,开启串口监视器,可以看到ESP8266每隔2秒钟会读取一次温湿度数据并打印到串口中,当度超过28°C时,蜂鸣器会响起一次,表示触发了报警。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Huang_xianlong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值