ESP32开发板创建同步WebServer网页服务器

ESP32开发板创建同步WebServer网页服务器

文章目录


前言

ESP32 内置了 Wi-Fi 功能,能够作为网页服务器(Web Server)向网络中的其他设备提供服务。通过在 ESP32 上运行网页服务器,可以创建基于浏览器的用户界面,用于监控传感器数据或控制设备状态,是实现物联网(IoT)应用的基础功能之一。

WebServer 库简介

Arduino-ESP32 核心库内置了 WebServer.h,它提供了一套简洁的 API 来快速构建 Web Server 轻量级的 HTTP 服务器。通过注册路由(URL 路径)及回调函数,实现请求分发与应答。适用于绝大多数典型 IOT 项目的本地网页交互。

选择建议

使用同步WebServer当:
轻量级,入门和资源受限场景,无需额外安装;
项目简单,只有一个用户;
请求处理非常快速(<100ms);
不需要同时处理其他重要任务;
内存资源非常有限;

使用异步WebServer当:
对大流量/高并发等复杂场景,需要高性能,服务多个用户;
有耗时操作(文件操作、网络请求);
需要实时功能(WebSocket);
需要处理上传/下载;
系统有其他重要任务需要及时响应;

同步阻塞模型,服务器一次只能处理一个客户端请求,必须等待当前请求完全处理完成后,才能处理下一个请求。

以下为同步WebServer与异步WebServer对比

在这里插入图片描述

基础网页服务 (STA 模式)

在 STA 模式下创建一个基础的网页服务器,用于显示一个包含"Hello World!"的静态页面。

#include<WiFi.h>#include<WebServer.h>constchar*ssid ="Maker";// 替换为你的 Wi-Fi 名称constchar*password ="12345678";// 替换为你的 Wi-Fi 密码 WebServer server(80);voidsetup(){ Serial.begin(115200);delay(10);// 连接 WiFi 网络 Serial.print("Connecting to "); Serial.println(ssid); WiFi.begin(ssid, password);// 等待连接成功while(WiFi.status()!= WL_CONNECTED){delay(500); Serial.print(".");} Serial.println(); Serial.println("WiFi connected."); Serial.println("IP address: "); Serial.println(WiFi.localIP());// 配置路由和启动服务器 server.on("/", handleRoot); server.begin();}voidloop(){ server.handleClient();}// 处理根路径请求voidhandleRoot(){ server.send(200,"text/html",generateHTML());}// 生成 HTML 页面内容 String generateHTML(){ String htmlContent ="<!DOCTYPE html> <html>\n"; htmlContent +="<head><meta charset=\"utf-8\" name=\"viewport\" content=\"width=device-width\">\n"; htmlContent +="<title>ESP32S3 Test</title>\n"; htmlContent +="</head><body>\n"; htmlContent +="<h1>Hello World!</h1>\n"; htmlContent +="<p>Hello from ESP32</p>\n"; htmlContent +="</body>\n"; htmlContent +="</html>\n";return htmlContent;}

代码解释​
#include <WebServer.h>:引入 Web Server 库,用以在 ESP32 上创建 HTTP 服务器。

WebServer server(80);:创建一个服务器对象,监听标准的 HTTP 端口 80。80 是 HTTP 协议的默认端口。

server.on(“/”, handleRoot);:注册路由处理函数。当客户端访问根路径"/"时,调用 handleRoot() 函数。

server.begin();:启动服务器,开始监听客户端的连接请求。

server.handleClient();:在 loop() 中持续调用,处理传入的客户端请求。

handleRoot():这是一个自定义的回调函数,用于处理特定路径的请求。

server.send(statusCode, contentType, content);:向客户端发送一个 HTTP 响应。向客户端浏览器返回包含 “Hello World” 的简单 HTML 页面。
200:HTTP 状态码,200 OK 表示请求成功。
“text/html”:MIME 类型,告知浏览器响应内容是 HTML 文本。
generateHTML():函数返回的字符串,即网页的实际内容。
generateHTML():一个辅助函数,将 HTML 代码拼接成一个 String 对象,返回包含完整 HTML 结构的字符串。

运行结果​

将代码中的 ssid 和 password 修改为目标 Wi-Fi 网络的名称和密码后上传。串口监视器将显示连接过程和获取到的 IP 地址。在同一局域网的设备上打开浏览器,输入显示的 IP 地址,即可看到"Hello World!"页面。

在这里插入图片描述


在这里插入图片描述

Read more

微软 Copilot Cowork 深度解析:用 Kotlin + 147API 手搓一个 AI Agent

微软 Copilot Cowork 深度解析:用 Kotlin + 147API 手搓一个 AI Agent

微软最近发布的 Copilot Cowork 在技术圈炸开了锅。它变了。它不再是那个只会补全代码的插件,而是变成了你的 “Coworker”(同事)。基于 Anthropic 的 Claude 构建,它现在能像真人一样处理复杂任务。 作为开发者,我们不仅要会用,更要懂得背后的原理。今天我们就来拆解一下 Copilot Cowork 的核心逻辑,并教你如何利用 Kotlin 和 147API 构建一个属于自己的简易 AI Agent。 从 Chatbot 到 Agent 传统的 Copilot 就像一个实习生,你给它一个指令,它执行一个动作。而 Copilot Cowork 更像是一个成熟的合作伙伴。它具备了 感知(Perception)、规划(Planning) 和 执行(Execution)

【OpenClaw:赚钱】案例19、内容产量5倍、广告收入翻4倍:播客转多平台内容矩阵全自动化实战(OpenAI Whisper + Claude)

【OpenClaw:赚钱】案例19、内容产量5倍、广告收入翻4倍:播客转多平台内容矩阵全自动化实战(OpenAI Whisper + Claude)

内容产量5倍、广告收入翻4倍:播客转多平台内容矩阵全自动化实战(OpenAI Whisper + Claude) 本文拆解内容创业者社区真实案例:用AI自动化将单期播客拆解为跨平台内容矩阵,内容产量提升5倍,广告月收入从¥8,000暴涨至¥35,000。从音频转写、内容提炼到多平台草稿生成,手把手教你打造高效内容分发流水线。 一、案例背景:内容创作者的效率革命 1.1 核心数据与业务本质 一位科技类播客主通过AI自动化内容矩阵系统,实现了内容生产与商业收入的双重飞跃: 核心指标优化前优化后提升幅度单期内容产量1期播客1套完整内容矩阵(6类内容)+500%周更新频率1次/周5次/周+400%月广告收入¥8,000¥35,000+337.5%内容生产耗时8小时/期1小时/期-87.5%平台覆盖仅播客播客+公众号+小红书+微博+LinkedIn+短视频+500%

Stable Diffusion WebUI本地部署全步骤(含CUDA,cuDNN,Pytorch GPU版安装过程)(Win 11 + RTX5060)

部署SD WebUI前,先安装CUDA+cuDNN+Pytorch 电脑配置: 系统:windows 11 显卡:NVIDIA GeForce RTX 5060 Laptop GPU 内存:24G 下载版本: CUDA:13.0 cuDNN:9.13.1 Pytorch:12.9 第一步:安装CUDA 步骤一:查看CUDA version win+R输入cmd,在命令提示符窗口中输入nvidia-smi,查看CUDA Version 我的CUDA version 为13.0,所以我下载的版本为13.0的(也可以向下安装低版本的,我建议下载最新的版本)。 CUDA下载网址:https://developer.