ESP32 + MicroPython 简易 Web 服务器教程

一、前言

在物联网开发中,让设备直接通过浏览器访问是一个非常常见的需求。ESP32 自带 WiFi,非常适合用来实现一个简单的 Web 服务器 。本文将基于 MicroPython,手把手教你在 ESP32 上搭建一个最基础的 HTTP Web Server,并通过浏览器访问。

适合人群:

  • ESP32 / MicroPython 初学者
  • 想快速实现网页访问 ESP32 的开发者

二、开发环境准备

1. 硬件准备

  • ESP32 开发板(任意型号)
  • USB 数据线

2. 软件准备

  • 已刷好 MicroPython 固件 的 ESP32
  • Thonny / uPyCraft / VS Code + MicroPython 插件
  • 可用的 WiFi 网络

⚠️ 注意:ESP32 需要刷入 MicroPython 固件,否则无法运行本文代码。


三、实现原理说明

整体流程如下:

  1. ESP32 连接 WiFi
  2. 获取 ESP32 的 IP 地址
  3. 创建 Socket 监听 80 端口
  4. 接收浏览器 HTTP 请求
  5. 返回 HTML 页面

浏览器访问 ESP32 的 IP,即可看到网页内容。


四、完整示例代码

python 复制代码
import network
import usocket as socket
import urequests

# 设置 WiFi 凭据
SSID = "wifi名称"
PASSWORD = "wifi密码"

# 创建 WLAN 对象
wlan = network.WLAN(network.STA_IF)

# 激活 WLAN 接口
wlan.active(True)

# 连接到 WiFi 网络
wlan.connect(SSID, PASSWORD)

# 等待连接完成
while not wlan.isconnected():
    pass

# 打印连接信息
print("Connected to WiFi")
print("Network config:", wlan.ifconfig())

# 定义简单的 HTTP 响应
HTML = """
HTTP/1.0 200 OK
Content-Type: text/html

<!DOCTYPE html>
<html>
<head><title>MicroPython Web Server</title></head>
<body>
<h1>Hello from MicroPython!</h1>
<p>This is a simple web server running on ESP32 with MicroPython.</p>
</body>
</html>
"""

# 创建套接字
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 绑定 IP 地址和端口
s.bind(('0.0.0.0', 80))

# 监听连接
s.listen(5)

# 循环接受和处理请求
while True:
    conn, addr = s.accept()
    print('Got a connection from %s' % str(addr))
    request = conn.recv(1024)
    print('Content = %s' % str(request))

    # 发送 HTTP 响应
    conn.sendall(HTML)
    conn.close()

五、代码详解

1️⃣ 连接 WiFi

python 复制代码
wlan = network.WLAN(network.STA_IF)
wlan.active(True)
wlan.connect(SSID, PASSWORD)
  • STA_IF:表示工作在 Station 模式(连接路由器)
  • isconnected():判断是否成功联网

2️⃣ 获取 ESP32 IP 地址

python 复制代码
print(wlan.ifconfig())

输出格式:

复制代码
(ip, subnet, gateway, dns)

记住这个 IP,后面浏览器要用。


3️⃣ 创建 Socket 服务器

python 复制代码
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind(('0.0.0.0', 80))
s.listen(5)

说明:

  • 0.0.0.0:监听所有网卡
  • 80:HTTP 默认端口
  • listen(5):最多同时处理 5 个连接

4️⃣ 处理 HTTP 请求

python 复制代码
conn, addr = s.accept()
request = conn.recv(1024)
conn.sendall(HTML)
conn.close()
  • accept():等待浏览器连接
  • recv():接收 HTTP 请求
  • sendall():返回 HTML 页面

六、浏览器访问测试

  1. 打开串口,查看 ESP32 的 IP 地址

  2. 在同一局域网下,浏览器输入:

    http://ESP32_IP

示例:

复制代码
http://192.168.31.250

如果看到网页内容,说明服务器运行成功 🎉

📌 原创不易,欢迎点赞 + 收藏 + 关注!

相关推荐
三佛科技-187366133974 小时前
FT838NB1-RT原边反馈5级能效电源控制器5V1A芯片电路图及管脚定义
单片机·嵌入式硬件·物联网
jianqiang.xue6 小时前
ESP32-P4 看门狗复位全解析:HP_SYS_HP_WDT_RESET 故障排查实战
单片机·mcu·esp32·idf
421!8 小时前
ESP32学习笔记之UART
笔记·学习·嵌入式·esp32·通信
物联通信量讯说9 小时前
企业级物联网卡服务商怎么选?——主流服务商类型对比与选型框架
物联网·信息与通信·iot·物联网卡·企业级物联网服务商
taxunjishu9 小时前
MODBUS TCP转Profinet 化工安全管控物联网网关实战案例
网络·物联网·自动化
jkyy20149 小时前
健康有益健康监测座舱:以科技之力,定义出行健康新标杆
大数据·人工智能·物联网·健康医疗
taxunjishu9 小时前
MODBUS TCP转Profinet 家纺织造塔讯物联网网关应用实操案例
物联网·网络协议·tcp/ip
华奥系科技1 天前
智慧经济新格局:解码社区、园区与城市一体化建设逻辑
大数据·人工智能·科技·物联网·安全
TDengine (老段)1 天前
TDengine IDMP 组态面板 —— 画布
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
蓝奥声科技1 天前
扩展式智能插座,破解多国标准与定制需求的新思路
物联网·智能用电计量插座·lpiot 低功耗物联网·外贸插座