ESP32 简单的WEB Server和GET参数读取示例
目录
要在ESP32上启动一个Web服务器,您可以使用Arduino IDE和ESPAsyncWebSrv库。以下是一个简单的示例,说明如何设置一个基本的Web服务器:
Arduino IDE中安装了ESP32开发板
首先,确保您已经在Arduino IDE中安装了ESP32开发板。如果尚未安装,请按照以下链接的说明进行操作:https://github.com/espressif/arduino-esp32/blob/master/docs/arduino-ide/boards_manager.md
安装所需的库
接下来,安装所需的库。在Arduino IDE中,转到“工具”>“管理库”,然后搜索并安装以下库:
-
ESPAsyncWebSrv
-
AsyncTCP(仅适用于ESP32)
-
ESPAsyncTCP(仅试用于ESP8266)
程序代码
创建一个新的Arduino项目,并将以下代码粘贴到项目中:
// welcome to lingshunlab.com
// A simple server implementation showing how to:
// * serve static messages
// * read GET parameters
// * handle missing pages / 404s
#include <Arduino.h>
#ifdef ESP32
#include <WiFi.h>
#include <AsyncTCP.h>
#elif defined(ESP8266)
#include <ESP8266WiFi.h>
#include <ESPAsyncTCP.h>
#endif
#include <ESPAsyncWebSrv.h>
AsyncWebServer server(80);
const char* ssid = "YOUR_SSID";
const char* password = "YOUR_PASSWORD";
const char* PARAM_MESSAGE = "message";
void notFound(AsyncWebServerRequest *request) {
request->send(404, "text/plain", "Not found");
}
void setup() {
Serial.begin(115200);
WiFi.mode(WIFI_STA);
WiFi.begin(ssid, password);
if (WiFi.waitForConnectResult() != WL_CONNECTED) {
Serial.printf("WiFi Failed!\n");
return;
}
Serial.println("WIFI connected!");
Serial.print("IP Address: ");
Serial.println(WiFi.localIP());
server.on("/", HTTP_GET, [](AsyncWebServerRequest *request){
request->send(200, "text/plain", "Hello, world");
});
// Send a GET request to <IP>/get?message=<message>
server.on("/get", HTTP_GET, [] (AsyncWebServerRequest *request) {
String message;
if (request->hasParam(PARAM_MESSAGE)) {
message = request->getParam(PARAM_MESSAGE)->value();
} else {
message = "No message sent";
}
request->send(200, "text/plain", "Hello, GET: " + message);
});
// Send a POST request to <IP>/post with a form field message set to <message>
server.on("/post", HTTP_POST, [](AsyncWebServerRequest *request){
String message;
if (request->hasParam(PARAM_MESSAGE, true)) {
message = request->getParam(PARAM_MESSAGE, true)->value();
} else {
message = "No message sent";
}
request->send(200, "text/plain", "Hello, POST: " + message);
});
server.onNotFound(notFound);
server.begin();
}
void loop() {
}
说明提点
1,修改代码中的YOUR_SSID和YOUR_PASSWORD,将其替换为您的Wi-Fi网络凭据。
2,将ESP32连接到计算机,然后在Arduino IDE中选择正确的端口和开发板。
3,上传代码到ESP32。
4,代码上传成功后,打开串行监视器。在串行监视器,您应该会看到ESP32连接到Wi-Fi网络的消息。一旦连接成功,它将显示“IP Address:xxx.xxx.xxx.xxx”。
5,然后在Web浏览器中输入该IP地址。您应该看到一个显示“Hello, world!”的简单HTML页面。
6,通过访问/get路径,使用?后接参数名称,即可实现与服务器的简单传递参数。
凌顺实验室在这个例子中展示了如何在ESP32上设置一个简单的Web服务器。您可以根据需要扩展此示例,以提供更复杂的网页和功能。