ESP32C3:手机连接开发板创建的热点WEB后,输入可用WIFI信息后进行联网

本文主要是介绍ESP32C3:手机连接开发板创建的热点WEB后,输入可用WIFI信息后进行联网,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

客户端测试:

 串口测试:

 逻辑解释:

- `#include <WiFi.h>` 和 `#include <WebServer.h>` 导入了其它库,用于 ESP32C3 与 Wi-Fi 和 Web 服务器的交互。
- `const char* ssid = "ESP32C3";` 定义了 Wi-Fi AP 的名称。
- `WebServer server(80);` 创建了一个 Web 服务器对象,并将其绑定到 80 端口。
- `handleRoot()`: 当 Web 服务器收到根路径(/)的 GET 请求时,会调用该函数,它在客户端网页上显示输入 Wi-Fi 凭据的表单。
- `handleConnect()`: 当 Web 服务器收到路由为 /connect 的 POST 请求时,会调用该函数。 该函数会从请求中获取 Wi-Fi 凭据并将其用于 Wi-Fi 连接。如果连接成功,则会向客户端发出成功消息;如果连接失败,则会向客户端发出失败信息。
- `setup()` 函数的作用是执行一些初始化操作,例如设置调试串口,开启 Wi-Fi 并将 ESP32 设置为 AP。它还将路由器映射到 `handleRoot()` 和 `handleConnect()` 函数上,并开始运行 Web 服务器。
- `loop()`函数是无限循环,在其中,调用 `server.handleClient()` 方法,以便服务器能够实时地处理客户端的请求。

代码部分:
 

#include <WiFi.h>
#include <WebServer.h>
const char* ssid = "ESP32C3";
WebServer server(80);
void handleRoot() {String html = "<form action='/connect' method='post'>Enter WiFi credentials:<br><input type='text' name='ssid' value=''><br><input type='password' name='password' value=''><br><input type='submit' value='Connect'></form>";server.send(200, "text/html", "<!DOCTYPE html><html><head><meta name='viewport' content='width=device-width, initial-scale=1.0'></head><body>"+html+"</body></html>");
}
void handleConnect() {String ssid = server.arg("ssid");String password = server.arg("password");Serial.println(ssid);Serial.println(password);WiFi.begin(ssid.c_str(), password.c_str());unsigned long timeout = millis();while (WiFi.status() != WL_CONNECTED && millis() - timeout < 10000) {delay(1000);}if (WiFi.status() == WL_CONNECTED) {server.send(200, "text/html", "<p>Connected to WiFi</p>");Serial.println("成功连接WIFI");} else {server.send(200, "text/html", "<p>Failed to connect to WiFi</p>");Serial.println("失败连接WIFI");}
}
void setup() {Serial.begin(115200);WiFi.mode(WIFI_AP_STA); // enable Station and AP modeWiFi.softAP(ssid);Serial.print("AP IP address: ");Serial.println(WiFi.softAPIP());server.on("/", handleRoot);server.on("/connect", HTTP_POST, handleConnect);server.begin();
}
void loop() {server.handleClient();
}

迭代版本:

1.增加LED展示效果:通电点亮+5V电源指示灯,联网成功双灯常亮模式,联网失败呼吸灯闪烁(失败后按RST重启连接热点重新给正确的WIFI信息)

2.增加企业微信机器人接口,联网成功会通知,通过访问:192.168.4.1/send?txt=XXX 还可进行消息推送

代码:
 

#define LED_BUILTIN_0 (12)
#define LED_BUILTIN_1 (13)#include <WiFi.h>
#include <WebServer.h>
#include <HTTPClient.h>
// 开发板热点名称
const char* ssid = "ESP32C3";
// 企业微信机器人 webhook URL
const char* webhookUrl = "请填写webhook URL";WebServer server(80);
void handleRoot() {String html = "<form action='/connect' method='post'>Enter WiFi credentials:<br><input type='text' name='ssid' value=''><br><input type='password' name='password' value=''><br><input type='submit' value='Connect'></form>";server.send(200, "text/html", "<!DOCTYPE html><html><head><meta name='viewport' content='width=device-width, initial-scale=1.0'></head><body>"+html+"</body></html>");
}
void handleSend() {if (WiFi.status() == WL_CONNECTED) {// 如 "/send?txt=test",其中的 "txt=test" 就是一个参数,使用 server.arg("txt") 可以获取它的值,即 "test"String message = "ESP32C3推送消息:" + server.arg("txt");Serial.println("接收到推送消息:");Serial.println(message);sendToWechatWebhook(message); // 调用sendToWechatWebhook函数发送请求字符串信息server.send(200, "text/plain", "消息推送成功!"); // 告诉客户端请求已完成Serial.println("推送消息成功!");} else {server.send(200, "text/plain", "无法连接网络,请检查网络连接!"); // 网络连接失败,返回错误提示Serial.println("推送消息失败!");}
}
void handleConnect() {String ssid = server.arg("ssid");String password = server.arg("password");Serial.println(ssid);Serial.println(password);WiFi.begin(ssid.c_str(), password.c_str());unsigned long timeout = millis();while (WiFi.status() != WL_CONNECTED && millis() - timeout < 10000) {Serial.println("Connecting to WiFi...");delay(1000);}if (WiFi.status() == WL_CONNECTED) {server.send(200, "text/html", "<p>Connected to WiFi</p>");Serial.println("成功连接WIFI");// 连接成功灯常亮,亮度偏低analogWrite(LED_BUILTIN_0, 10);analogWrite(LED_BUILTIN_1, 10); // 发送消息到企业微信机器人String message = "ESP32C3 成功连接了 WiFi " + String(ssid);sendToWechatWebhook(message);} else {server.send(200, "text/html", "<p>Failed to connect to WiFi</p>");Serial.println("失败连接WIFI");while (true) {// 渐亮,范围0-255for (int i = 0; i < 100; i++) {analogWrite(LED_BUILTIN_0, i);analogWrite(LED_BUILTIN_1, i);delay(10); }// 渐灭范围255-0for (int i = 100; i >= 0; i--) {analogWrite(LED_BUILTIN_0, i);analogWrite(LED_BUILTIN_1, i);delay(10); }}}
}
void setup() {Serial.begin(115200);//只量一个电源灯pinMode(LED_BUILTIN_1, OUTPUT);WiFi.mode(WIFI_AP_STA); // enable Station and AP modeWiFi.softAP(ssid);Serial.print("AP IP address: ");Serial.println(WiFi.softAPIP());server.on("/", handleRoot);server.on("/connect", HTTP_POST, handleConnect);server.on("/send", HTTP_GET, handleSend); server.begin();
}
void loop() {server.handleClient();
}
void sendToWechatWebhook(String message) {HTTPClient https;https.begin(webhookUrl);String payload = "{\"msgtype\":\"text\",\"text\":{\"content\":\"" + message + "\"}}";int httpResponseCode = https.POST(payload);if (httpResponseCode == HTTP_CODE_OK) {Serial.println("Message sent to WeChat webhook");} else {Serial.println("Failed to send message to WeChat webhook");}https.end();
}

这篇关于ESP32C3:手机连接开发板创建的热点WEB后,输入可用WIFI信息后进行联网的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存