创客入门神器(ESP32+Arduino)10分钟实现web控制LED

创客入门神器(ESP32+Arduino)10分钟实现web控制LED

在AI大模型技术浪潮的推动下,编程正从专业领域走向大众化。以ESP32和Arduino为代表的开源硬件平台,正在系统性降低创客的电子开发门槛,让创意落地变得前所未有的简单。随着AI编程工具与开源硬件的深度融合,电子创作正经历从"技术驱动"到"创意驱动"的转变。这种变革不仅催生了更多教育科技产品,更预示着智能硬件开发将迎来全民化时代,让每个普通人都能成为改变世界的创客。

ESP32C3SuperMini是一款基于 Espressif ESP32-C3 WiFi/蓝牙双模芯片的 IoT 迷你开发板。ESP32-C3 是一款32 位 RISC-V CPU,包含FPU(浮点单元),支持IEEE 802.11 b/g/n WiFi和蓝牙 5 (LE)协议。该板附带外部天线,可增强无线应用的信号强度。有11个可用作PWM引脚的数字I/O和4个可用作ADC引脚的模拟I/O。它支持UART、I2C 和 SPI等四种串行接口。

ESP32C3SuperMini定位为高性能、低功耗、高性价比的物联网迷你开发板,适用于低功耗物联网应用和无线可穿戴应用。

一、快速开始

(1)硬件环境:

  • 1 个ESP32C3SuperMini
  • 1 台电脑
  • 1 根 USB Type-C数据线

(2)软件环境:

Arduino IDE下载安装

到arduino官方网站下载,你电脑操作系统对应的Arduino IDE版本。

https://www.arduino.cc/en/software/

查找esp32,选esp32 by Espressif Systems,2.0.17-cn版本(3.x.x版本安装下载失败):

2、设置开发板型号与端口

选择设置好对应的开发板型号:

设置开发板下载与通信串口:

首先在windows系统中查找对应的设备串口号,例如下图中显示的COM14。

注:如果开发板通过type-c数据线接入PC,系统没有显示串口设备,是数据线问题或板子问题;显示异常设备是串口驱动没有安装。

在文件 > 工具,选中对应的开发板及端口。

到这一步软硬件环境就准备好,下面就进行编程开发。

二、编程与下载运行

(1)控制LED灯

菜单中打开文件 > 新建项目。

步骤1.将以下代码复制到Arduino IDE的新建项目区。

// 设置LED使用的GPIO引脚 int led = 8; void setup() { // 初始化GPIO为输出模式 pinMode(led, OUTPUT); } void loop() { digitalWrite(led, HIGH); // turn the LED off delay(1000); //延时1000ms digitalWrite(led, LOW); // turn the LED on delay(1000); //延时1000ms }

保存项目,选择工具栏上右箭头图标"-->"编译并上传项目。

上传后,您将看到板子上的LED 闪烁,每次闪烁之间有 1 秒的延迟。

(2)web控制LED灯

#include <WiFi.h> const char* ssid = "wifi"; // 设置wifi名称 const char* password = "1234"; // 设置wifi密码 WiFiServer server(80); //wifi服务器对象初始化 void setup() { Serial.begin(115200); pinMode(8, OUTPUT); delay(10); Serial.println(); 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.begin(); } void loop(){ WiFiClient client = server.available(); // if (client) { Serial.println("New Client."); String; while (client.connected()) { if (client.available()) { char c = client.read(); Serial.write(c); if (c == '\n') { if (currentLine.length() == 0) { client.println("HTTP/1.1 200 OK"); client.println("Content-Type: text/html; charset=utf-8"); client.println(); client.print("<div>"); client.print("Click <a href=\"/L\">打开LED</a><br><br>"); client.print("Click <a href=\"/H\">关闭LED</a>"); client.print("</div>"); client.println(); break; } else {; } } else if (c != '\r') { currentLine += c; } if (currentLine.endsWith("GET /H")) { digitalWrite(8, HIGH); } if (currentLine.endsWith("GET /L")) { digitalWrite(8, LOW); } } } client.stop(); Serial.println("Client Disconnected."); } }

注:有时网络连接异常时需要按一下boot键

浏览器中输出串口显示的开发板IP,出现下述页面就可控制板上的LED灯。

三、实现原理分析

(1)实现原理

1、代码整体功能

代码实现了两个核心功能:

  1. ESP32 作为 WiFi 客户端,连接到指定名称和密码的路由器,获取局域网 IP 地址;
  2. 在 ESP32 上启动一个基于 TCP 80 端口的简易 Web 服务器,当电脑 / 手机浏览器访问该 IP 时,会显示两个超链接:点击 /H 打开引脚 8 的 LED,点击 /L 关闭引脚 8 的 LED。

2、Web 服务原理

Web 服务基于 HTTP 协议 + TCP 80 端口 实现,核心是 “请求 - 响应” 模型:

  1. ESP32 启动 TCP 服务器监听 80 端口(HTTP 协议默认端口);
  2. 浏览器(客户端)向 ESP32 的 IP:80 发送 HTTP 请求(如 GET /LGET /H);
  3. ESP32 解析请求内容,根据请求数据(/H//L)执行对应操作(返回网页 / 控制 LED);
  4. ESP32 向浏览器返回 HTTP 响应(状态码、网页内容),完成一次交互后关闭连接。

3、核心工作流程

  1. WiFi 连网核心:通过 WiFi.begin() 发起连接,WiFi.status() 等待连接成功,WiFi.localIP() 获取访问地址;
  2. Web 服务核心WiFiServer 监听 80 端口,server.available() 检测客户端连接,通过 client.read() 解析 HTTP 请求路径,client.print() 返回响应内容;
  3. 业务逻辑核心:通过判断请求路径(GET /H/GET /L),调用 digitalWrite() 控制 LED 电平。

(2)关键函数分析

1、WiFi 连网相关

代码 / 函数

作用与使用说明

WiFi.begin(ssid, password)

核心连网函数:传入 WiFi 名称(ssid)和密码(password),触发 ESP32 向指定路由器发起连接请求。⚠️ 注意:调用后不会立即连接成功,需要等待状态确认。

WiFi.status()

检测 WiFi 连接状态的核心函数,返回值是枚举类型,代码中只关注 WL_CONNECTED

(连接成功),其他常见值:- WL_DISCONNECTED

:未连接;- WL_CONNECT_FAILED

:密码错误 / SSID 不存在;- WL_NO_SSID_AVAIL

:未找到指定 WiFi。

WiFi.localIP()

连接成功后,获取 ESP32 在局域网中的 IP 地址(如 192.168.1.100),这是浏览器访问 Web 服务的核心地址,通过串口打印出来供用户查看。

while (WiFi.status() != WL_CONNECTED)

循环等待连网:因为 WiFi 连接需要 1~3 秒,通过 500ms 延时的循环,直到状态变为 “已连接” 才继续执行后续代码(启动 Web 服务器)。

2、Web 服务相关

核心对象与启动函数

代码 / 函数

作用与使用说明

WiFiServer server(80)

创建 TCP 服务器对象,指定监听 80 端口(HTTP 协议默认端口,浏览器访问时无需手动加端口)。

server.begin()

启动 Web 服务器:让 ESP32 开始监听 80 端口的客户端连接请求(如浏览器的访问)。

WiFiClient client = server.available()

检测是否有客户端(浏览器)发起连接请求:- 无请求时返回空,client为 false;- 有请求时返回一个客户端对象,代表与该浏览器的连接,后续通过这个对象读写数据。

客户端交互核心逻辑
if (client) { // 有客户端连接 while (client.connected()) { // 只要客户端未断开连接,就持续处理 if (client.available()) { // 检测客户端是否有数据(HTTP 请求)发送过来 char c = client.read(); // 读取一个字节的请求数据 // ... 解析数据、处理请求 ... } } client.stop(); // 处理完请求后,关闭与客户端的连接 }

代码 / 函数

作用与使用说明

client.connected()

判断当前客户端是否处于连接状态:如果浏览器还没断开,就继续处理数据;如果断开,结束循环。

client.available()

检测客户端是否有可读取的字节(即浏览器发送的 HTTP 请求内容),返回可读取的字节数,非 0 时表示有数据。

client.read()

读取客户端发送的一个字节数据:HTTP 请求是文本格式(如 GET /H HTTP/1.1),通过逐字节读取来解析请求路径。

client.println()

/client.print()

向客户端(浏览器)发送响应数据:

- println():发送字符串 + 换行符;

- print():仅发送字符串;代码中用来返回 HTTP 响应头、网页 HTML 内容。

client.stop()

关闭与客户端的连接:HTTP 是 “短连接”,处理完一次请求后主动关闭连接,释放资源。

HTTP 请求解析逻辑(代码中最核心的业务处理)

浏览器发送的 HTTP 请求示例(点击 /H 时):

GET /H HTTP/1.1 Host: 192.168.1.100 ...(其他请求头)

代码通过逐字节读取拼接成 currentLine,再通过以下逻辑解析:

代码逻辑

作用与使用说明

if (c == '\n')

检测换行符:HTTP 请求的每行内容以 \r\n结尾,\n

代表一行的结束。如果 currentLine为空(连续两个 \n),说明请求头解析完成,开始返回响应。

currentLine += c

(c != '\r')

拼接请求行内容:跳过回车符 \r,将有效字符拼接成 currentLine

,最终得到如 GET /H HTTP/1.1 的字符串。

currentLine.endsWith("GET /H")

解析请求路径:判断请求是否是 “打开 LED”,如果是,执行 digitalWrite(8, HIGH);同理,endsWith("GET /L")对应关闭 LED。

HTTP 响应头(client.println("HTTP/1.1 200 OK")

向浏览器返回响应状态:- HTTP/1.1 200 OK

:表示请求处理成功;- Content-type:text/html

:告诉浏览器返回的是 HTML 格式内容;响应头结束后必须加一个空行(client.println()

),这是 HTTP 协议的要求。

3、硬件控制相关

代码 / 函数

作用与使用说明

pinMode(8, OUTPUT)

将引脚 8 设置为输出模式:ESP32 控制 LED 必须先设置引脚模式为输出。

digitalWrite(8, HIGH/LOW)

控制引脚电平:HIGH 为高电平(LED 亮),LOW 为低电平(LED 灭),对应解析后的 /H//L请求执行。

Read more

Local Moondream2实战案例:独立开发者用其构建AI绘画灵感助手App

Local Moondream2实战案例:独立开发者用其构建AI绘画灵感助手App 你有没有遇到过这样的创作瓶颈?脑子里有个模糊的画面,却怎么也找不到合适的词语来描述它,AI绘画工具生成的图片总是差那么点意思。或者,在网上看到一张惊艳的图片,想学习它的构图和风格,却不知从何分析起。 对于独立开发者或小型创意团队来说,聘请专业的设计师或购买昂贵的创意工具往往成本高昂。今天,我要分享一个实战案例:如何利用一个名为 Local Moondream2 的超轻量级工具,快速构建一个完全运行在你个人电脑上的“AI绘画灵感助手”,彻底解决上述痛点。 1. 为什么选择Local Moondream2? 在开始动手之前,我们先搞清楚这个工具到底能做什么,以及它为何适合独立开发者。 简单来说,Local Moondream2 是一个给你的电脑装上“眼睛”的本地化应用。你上传任何图片,它都能“看懂”,并用英文告诉你图片里有什么。它的核心能力有三项,每一项都对创意工作者极具价值: * 详细描述图片:它能生成一段极其详尽的英文描述,远超简单的“一只猫在沙发上”。这段描述可以直接用作AI绘画(如S

芯片制造行业如何通过WebUploader+PHP加密传输工程文件的分片数据?

《一个码农的奇幻外包漂流记》 需求分析会:当甲方爸爸说出"简单"二字时… 各位老铁们好!我是辽宁沈阳一名"资深"前端码农(资深=头发少)。刚接到个外包需求,看完后我直接表演了个东北式懵逼: 甲方需求翻译大赛: * “要支持20G文件” → “希望你电脑硬盘够大” * “兼容IE9” → “希望你心态够好” * “1000+文件的文件夹结构” → “希望你记忆力超群” * “预算100元含3年维护” → “希望你家里有矿” * “7×24小时支持” → “希望你不需要睡觉” 技术选型:穷且益坚版解决方案 前端部分(Vue3+原生JS缝合怪版) // 文件夹上传器(贫困版)classDiaoSiFolderUploader{constructor(){this.chunkSize =5*1024*1024;// 5MB一片this.maxTry =99;// 最大重试次数(因为甲方网络是2G)this.

(附源码)基于Java web的在线考试系统的设计与实现-计算机毕设 33482

(附源码)基于Java web的在线考试系统的设计与实现-计算机毕设 33482

基于Java web的在线考试系统的设计与实现 摘  要 随着信息技术的迅速发展,教育行业对在线考试系统的需求不断增加,尤其是在数字化转型的背景下,传统的人工考试管理方式逐渐暴露出诸多问题,如效率低、资源浪费、信息滞后等。为了提升考试管理的效率和学生的学习体验,在线考试系统的开发显得尤为重要。 该系统的功能设计主要包括:学生在线报名、考试、成绩查询、错题管理等功能;教师可以发布、编辑试卷、批改作业、查看成绩分析等;管理员负责系统用户管理、考试资源调度、公告发布等。系统通过清晰的角色分配,确保各类用户能够高效使用系统,实现学习、教学和管理的数字化与智能化。 技术方案上,系统前端采用Vue.js框架构建,实现与用户的良好交互;后端使用SpringBoot框架,结合Java语言进行业务逻辑处理,确保系统的高性能和可扩展性;MySQL数据库用于存储用户数据、考试成绩、题库信息等,保障数据的高效管理和查询性能。 通过在线考试系统的实施能够大幅提升考试管理效率,减少人工干预,优化资源分配,增强学生的参与感和互动体验。该系统不仅能帮助教育机构实现信息化管理,还能为学生和教师提供便捷

微信小程序webview postmessage通信指南

微信小程序webview postmessage通信指南

需求概述 在微信小程序中使用 web-view 组件与内嵌网页进行双向通信,主要通过 postMessage 实现。以下是完整的配置和使用方法: 通信指南 微信小程序webview官方文档 1. 基础配置 小程序端配置 // app.json 或 page.json { "usingComponents": {}, "permission": { "scope.webView": { "desc": "用于网页和小程序通信" } } } 网页端配置 <!-- 内嵌网页需引入微信JS-SDK --> <script src="https://res.wx.qq.com/open/