首页
NodeMcu
NodeMcu_ESP8266开发板--TCP Server
NodeMcu_ESP8266简介
NodeMcu_温湿度传感器(DHT11)的使用
esp8266+DHT11温湿传感器 制作web室内温度计
ESP8266NodeMcu网页控制四个LED灯
NodeMcu用网页上传图片来驱动1.44寸TFT屏幕
esp8266使用1.44寸tft屏Arduino模块示例程序
1.44寸TFT屏ST7735使用方法
NodeMcu_ESP8266编程
NodeMcu环境监控+远程控制
NodeMcu实现网页远程控制+温湿度显示
NodeMcu网页控制+温湿度显示+TFT
NodeMcu、ESP8266、ESP32区别
本文档由 内网文摘 发布,转载请注明出处
-
+
首页
ESP8266NodeMcu网页控制四个LED灯
转发:[ESP8266NodeMcu网页控制四个LED页面](https://blog.csdn.net/luanchen123/article/details/114898217 "ESP8266NodeMcu网页控制四个LED页面") 说明: 在太极创客教程基础上进行添加和修改,以下是源代码和增添D1、D2、D3引脚后的代码。 #### 原代码 ```cpp 项目名称/Project : 零基础入门学用物联网 程序名称/Program name : 3_2_2_Turning_on_and_off_an_LED 团队/Team : 太极创客团队 / Taichi-Maker (www.taichi-maker.com) 作者/Author : CYNO朔 日期/Date(YYYYMMDD) : 20191108 程序目的/Purpose : 使用NodeMCU建立基本服务器。用户可通过浏览器使用8266的IP地址 访问8266所建立的基本网页并通过该页面点亮/熄灭NodeMCU的内置LED ----------------------------------------------------------------------- 修订历史/Revision History 日期/Date 作者/Author 参考号/Ref 修订说明/Revision Description ***********************************************************************/ #include <ESP8266WiFi.h> // 本程序使用 ESP8266WiFi库 #include <ESP8266WiFiMulti.h> // ESP8266WiFiMulti库 #include <ESP8266WebServer.h> // ESP8266WebServer库 ESP8266WiFiMulti wifiMulti; // 建立ESP8266WiFiMulti对象,对象名称是 'wifiMulti' ESP8266WebServer esp8266_server(80);// 建立网络服务器对象,该对象用于响应HTTP请求。监听端口(80) void setup(void){ Serial.begin(9600); // 启动串口通讯 pinMode(LED_BUILTIN, OUTPUT); //设置内置LED引脚为输出模式以便控制LED wifiMulti.addAP("ssid_from_AP_1", "your_password_for_AP_1"); // 将需要连接的一系列WiFi ID和密码输入这里 wifiMulti.addAP("ssid_from_AP_2", "your_password_for_AP_2"); // ESP8266-NodeMCU再启动后会扫描当前网络 wifiMulti.addAP("ssid_from_AP_3", "your_password_for_AP_3"); // 环境查找是否有这里列出的WiFi ID。如果有 Serial.println("Connecting ..."); // 则尝试使用此处存储的密码进行连接。 int i = 0; while (wifiMulti.run() != WL_CONNECTED) { // 此处的wifiMulti.run()是重点。通过wifiMulti.run(),NodeMCU将会在当前 delay(1000); // 环境中搜索addAP函数所存储的WiFi。如果搜到多个存储的WiFi那么NodeMCU Serial.print(i++); Serial.print(' '); // 将会连接信号最强的那一个WiFi信号。 } // 一旦连接WiFI成功,wifiMulti.run()将会返回“WL_CONNECTED”。这也是 // 此处while循环判断是否跳出循环的条件。 // WiFi连接成功后将通过串口监视器输出连接成功信息 Serial.println('\n'); Serial.print("Connected to "); Serial.println(WiFi.SSID()); // 通过串口监视器输出连接的WiFi名称 Serial.print("IP address:\t"); Serial.println(WiFi.localIP()); // 通过串口监视器输出ESP8266-NodeMCU的IP esp8266_server.begin(); // 启动网站服务 esp8266_server.on("/", HTTP_GET, handleRoot); // 设置服务器根目录即'/'的函数'handleRoot' esp8266_server.on("/LED", HTTP_POST, handleLED); // 设置处理LED控制请求的函数'handleLED' esp8266_server.onNotFound(handleNotFound); // 设置处理404情况的函数'handleNotFound' Serial.println("HTTP esp8266_server started");// 告知用户ESP8266网络服务功能已经启动 } void loop(void){ esp8266_server.handleClient(); // 检查http服务器访问 } /*设置服务器根目录即'/'的函数'handleRoot' 该函数的作用是每当有客户端访问NodeMCU服务器根目录时, NodeMCU都会向访问设备发送 HTTP 状态 200 (Ok) 这是send函数的第一个参数。 同时NodeMCU还会向浏览器发送HTML代码,以下示例中send函数中第三个参数, 也就是双引号中的内容就是NodeMCU发送的HTML代码。该代码可在网页中产生LED控制按钮。 当用户按下按钮时,浏览器将会向NodeMCU的/LED页面发送HTTP请求,请求方式为POST。 NodeMCU接收到此请求后将会执行handleLED函数内容*/ void handleRoot() { esp8266_server.send(200, "text/html", "<form action=\"/LED\" method=\"POST\"><input type=\"submit\" value=\"Toggle LED\"></form>"); } //处理LED控制请求的函数'handleLED' void handleLED() { digitalWrite(LED_BUILTIN,!digitalRead(LED_BUILTIN));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } // 设置处理404情况的函数'handleNotFound' void handleNotFound(){ esp8266_server.send(404, "text/plain", "404: Not found"); // 发送 HTTP 状态 404 (未找到页面) 并向浏览器发送文字 "404: Not found" } ``` #### 增加后代码 ```cpp /********************************************************************** 项目名称/Project : 零基础入门学用物联网 程序名称/Program name : 3_2_2_Turning_on_and_off_an_LED 团队/Team : 太极创客团队 / Taichi-Maker (www.taichi-maker.com) 作者/Author : CYNO朔 日期/Date(YYYYMMDD) : 20191108 程序目的/Purpose : 使用NodeMCU建立基本服务器。用户可通过浏览器使用8266的IP地址 访问8266所建立的基本网页并通过该页面点亮/熄灭NodeMCU的内置LED ----------------------------------------------------------------------- 修订历史/Revision History 日期/Date 作者/Author 参考号/Ref 修订说明/Revision Description ***********************************************************************/ #include <ESP8266WiFi.h> // 本程序使用 ESP8266WiFi库 #include <ESP8266WiFiMulti.h> // ESP8266WiFiMulti库 #include <ESP8266WebServer.h> // ESP8266WebServer库 ESP8266WiFiMulti wifiMulti; // 建立ESP8266WiFiMulti对象,对象名称是 'wifiMulti' ESP8266WebServer esp8266_server(80);// 建立网络服务器对象,该对象用于响应HTTP请求。监听端口(80) int LEDYellow=D1;//GPIO5,D1引脚 int LEDWhit=D2;//GPIO4,D2引脚 int LEDBlue=D3;//GPIO0,D3引脚 void setup(void){ Serial.begin(9600); // 启动串口通讯 pinMode(LED_BUILTIN, OUTPUT); //设置内置LED引脚为输出模式以便控制LED pinMode(D1,OUTPUT); //设置D1引脚为输出模式以便控制黄色LED pinMode(D2, OUTPUT); //设置D2引脚为输出模式以便控制白色LED pinMode(D3, OUTPUT); //设置D3引脚为输出模式以便控制蓝色LED wifiMulti.addAP("360WiFi-F84640", "12345678"); // 将需要连接的一系列WiFi ID和密码输入这里 wifiMulti.addAP("ssid_from_AP_2", "your_password_for_AP_2"); // ESP8266-NodeMCU再启动后会扫描当前网络 wifiMulti.addAP("ssid_from_AP_3", "your_password_for_AP_3"); // 环境查找是否有这里列出的WiFi ID。如果有 Serial.println("Connecting ..."); // 则尝试使用此处存储的密码进行连接。 int i = 0; while (wifiMulti.run() != WL_CONNECTED) { // 此处的wifiMulti.run()是重点。通过wifiMulti.run(),NodeMCU将会在当前 delay(1000); // 环境中搜索addAP函数所存储的WiFi。如果搜到多个存储的WiFi那么NodeMCU Serial.print(i++); Serial.print(' '); // 将会连接信号最强的那一个WiFi信号。 } // 一旦连接WiFI成功,wifiMulti.run()将会返回“WL_CONNECTED”。这也是 // 此处while循环判断是否跳出循环的条件。 // WiFi连接成功后将通过串口监视器输出连接成功信息 Serial.println('\n'); Serial.print("Connected to "); Serial.println(WiFi.SSID()); // 通过串口监视器输出连接的WiFi名称 Serial.print("IP address:\t"); Serial.println(WiFi.localIP()); // 通过串口监视器输出ESP8266-NodeMCU的IP esp8266_server.begin(); // 启动网站服务 esp8266_server.on("/", HTTP_GET, handleRoot); // 设置服务器根目录即'/'的函数'handleRoot' esp8266_server.on("/LED", HTTP_POST, handleLED); // 设置处理LED控制请求的函数'handleLED' esp8266_server.on("/LED1", HTTP_POST, handleLEDYellow); // 设置处理LED控制请求的函数'handleLED' esp8266_server.on("/LED2", HTTP_POST, handleLEDWhite); // 设置处理LED控制请求的函数'handleLED' esp8266_server.on("/LED3", HTTP_POST, handleLEDBlue); // 设置处理LED控制请求的函数'handleLED' esp8266_server.onNotFound(handleNotFound); // 设置处理404情况的函数'handleNotFound' Serial.println("HTTP esp8266_server started");// 告知用户ESP8266网络服务功能已经启动 } void loop(void){ esp8266_server.handleClient(); // 检查http服务器访问 } /*设置服务器根目录即'/'的函数'handleRoot' 该函数的作用是每当有客户端访问NodeMCU服务器根目录时, NodeMCU都会向访问设备发送 HTTP 状态 200 (Ok) 这是send函数的第一个参数。 同时NodeMCU还会向浏览器发送HTML代码,以下示例中send函数中第三个参数, 也就是双引号中的内容就是NodeMCU发送的HTML代码。该代码可在网页中产生LED控制按钮。 当用户按下按钮时,浏览器将会向NodeMCU的/LED页面发送HTTP请求,请求方式为POST。 NodeMCU接收到此请求后将会执行handleLED函数内容*/ void handleRoot() { esp8266_server.send(200, "text/html", "<form action=\"/LED\" method=\"POST\"><input type=\"submit\" value=\"Toggle LED\"></form><form action=\"/LED1\" method=\"POST\"><input type=\"submit\" value=\"Toggle LEDYellow\"></form><form action=\"/LED2\" method=\"POST\"><input type=\"submit\" value=\"Toggle LEDWhite\"></form><form action=\"/LED3\" method=\"POST\"><input type=\"submit\" value=\"Toggle LEDBlue\"></form>"); } //处理LED控制请求的函数'handleLED' void handleLED() { digitalWrite(LED_BUILTIN,!digitalRead(LED_BUILTIN));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } void handleLEDYellow() { digitalWrite(D1,!digitalRead(5));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } void handleLEDWhite() { digitalWrite(D2,!digitalRead(4));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } void handleLEDBlue() { digitalWrite(D3,!digitalRead(0));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } // 设置处理404情况的函数'handleNotFound' void handleNotFound(){ esp8266_server.send(404, "text/plain", "404: Not found"); // 发送 HTTP 状态 404 (未找到页面) 并向浏览器发送文字 "404: Not found" } ``` 修改部分 ```cpp esp8266_server.on("/LED1", HTTP_POST, handleLEDYellow); // 设置处理LED控制请求的函数'handleLED' esp8266_server.on("/LED2", HTTP_POST, handleLEDWhite); // 设置处理LED控制请求的函数'handleLED' esp8266_server.on("/LED3", HTTP_POST, handleLEDBlue); // 设置处理LED控制请求的函数'handleLED' ``` ```cpp void handleLEDYellow() { digitalWrite(D1,!digitalRead(5));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } void handleLEDWhite() { digitalWrite(D2,!digitalRead(4));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } void handleLEDBlue() { digitalWrite(D3,!digitalRead(0));// 改变LED的点亮或者熄灭状态 esp8266_server.sendHeader("Location","/"); // 跳转回页面根目录 esp8266_server.send(303); // 发送Http相应代码303 跳转 } ``` 浏览器网页效果图 ![](/media/202110/2021-10-27_145003.png)
local
2021年10月27日 14:50
分享文档
收藏文档
上一篇
下一篇
微信扫一扫
复制链接
手机扫一扫进行分享
复制链接
关于 LocalNetwork
LocalNetwork
是由mrdoc开源
LocalNetwork.cn
修改的在线文档系统,作为个人和小型团队的云笔记、文档和知识库管理工具。
如果此文档给你或你的团队带来了帮助,欢迎支持作者持续投入精力更新和维护!内网文摘 & LocalNetwork
>>>主页
logo
logo
下载Markdown文件
分享
链接
类型
密码
更新密码