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

Posted xianlong_Huang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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已联网,都是可以收到信息的。

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

以上是关于ESP8266连接DHT11收集数据上传微信小程序实现实时温湿度监测的主要内容,如果未能解决你的问题,请参考以下文章

ESP 保姆级教程 疯狂传感器篇 —— 案例:ESP8266 + DHT11 + OLED + 巴法云平台 + 微信小程序(曲线图)预告中

基于51单片机+DHT11温湿度模块+ESP8266模块+上传oneNET APP显示+LCD1602显示

本篇更完ESP 保姆级教程 疯狂传感器篇 —— 案例:ESP8266 + DHT11 + 自定义微信告警

ESP8266 SDK开发: 微信小程序篇-微信小程序通过UDP实现和ESP8266局域网通信控制

ESP8266 SDK开发: 微信小程序篇-微信小程序通过UDP实现和ESP8266局域网通信控制

Arduio ESP8266获取DHT11温湿度传感器数据