ESP-01S 通过手机点亮led灯

手机控制ESP8266 LED亮灭(零基础10分钟搞定)

核心思路:让ESP8266作为WiFi热点 (或连接家里路由器),手机通过浏览器/小程序发送指令,ESP8266接收指令后控制LED。

我给你最简化的方案(不用装APP,浏览器直接控制),全程基于Arduino IDE,代码复制即用。


第一步:核心准备(沿用之前的硬件)

  • ESP8266开发板(NodeMCU/ESP-12E)
  • USB线+电脑(已装Arduino IDE和ESP8266库)
  • 手机(连WiFi)

第二步:编写代码(5分钟)

清空Arduino IDE原有代码,粘贴以下代码(只需改2处:WiFi名称+密码):

arduino 复制代码
#include <ESP8266WiFi.h>
#include <ESP8266WebServer.h>

// *************************
// 改这里:你的WiFi名称和密码(家里路由器/手机热点)
const char* ssid = "你的WiFi名称";
const char* password = "你的WiFi密码";
// *************************

ESP8266WebServer server(80); // 搭建Web服务器,端口80
const int ledPin = 2; // ESP8266板载LED引脚(不用改)

// LED亮的处理函数
void handleLEDOn() {
  digitalWrite(ledPin, LOW); // 板载LED低电平亮
  server.send(200, "text/plain", "LED已点亮 ✅");
}

// LED灭的处理函数
void handleLEDOff() {
  digitalWrite(ledPin, HIGH); // 板载LED高电平灭
  server.send(200, "text/plain", "LED已熄灭 ❌");
}

void setup() {
  pinMode(ledPin, OUTPUT);
  digitalWrite(ledPin, HIGH); // 初始状态灭
  
  // 连接WiFi
  WiFi.begin(ssid, password);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
  }
  
  // 打印ESP8266的IP地址(关键!手机要访问这个IP)
  Serial.begin(115200);
  Serial.println("WiFi已连接,ESP8266的IP地址:");
  Serial.println(WiFi.localIP()); // 比如:192.168.1.100

  // 配置网页路由(手机访问的地址)
  server.on("/on", handleLEDOn);    // 访问 /on 亮灯
  server.on("/off", handleLEDOff);  // 访问 /off 灭灯
  server.begin(); // 启动服务器
}

void loop() {
  server.handleClient(); // 监听手机指令
}

第三步:上传代码并查看ESP8266的IP(2分钟)

  1. 点击IDE「√」验证代码(确保无报错);
  2. 点击「→」上传代码到ESP8266;
  3. 上传完成后,点击IDE右上角「串口监视器」(📞图标),波特率选「115200」;
  4. 等待串口打印出「WiFi已连接,ESP8266的IP地址:xxx.xxx.xxx.xxx」(比如192.168.1.100),记下来这个IP!

第四步:手机控制(3分钟)

  1. 手机连接和ESP8266同一个WiFi(就是代码里填的那个WiFi);
  2. 打开手机浏览器(微信/支付宝/Chrome都可以),在地址栏输入:
    • 亮灯:http://ESP8266的IP地址/on(比如http://192.168.1.100/on
    • 灭灯:http://ESP8266的IP地址/off(比如http://192.168.1.100/off
  3. 回车后,浏览器会显示「LED已点亮/熄灭」,同时开发板上的LED立刻响应!


进阶:做个可视化控制页面(可选,更友好)

如果不想输网址,把代码里的setup()中「配置网页路由」部分替换成下面这段,手机访问ESP8266的IP地址会出现按钮:

cpp 复制代码
// 替换原有server.on("/on"... 这部分)
server.on("/", []() {
  String html = "<html><body>";
  html += "<h1>ESP8266 LED控制</h1>";
  html += "<button style='font-size:20px;padding:20px;' onclick='location.href=\"/on\"'>点亮LED</button>";
  html += "<button style='font-size:20px;padding:20px;' onclick='location.href=\"/off\"'>熄灭LED</button>";
  html += "</body></html>";
  server.send(200, "text/html", html);
});
server.on("/on", handleLEDOn);
server.on("/off", handleLEDOff);

上传后,手机访问ESP8266的IP地址,直接点按钮就能控制,不用输网址!


试验成功,但是响应有点慢啊

避坑关键

  1. WiFi必须一致:手机和ESP8266要连同一个WiFi,否则访问不到;
  2. IP地址要正确:串口打印的IP可能会变,每次重启ESP8266后最好查一下;
  3. 板载LED引脚:ESP8266板载LED是GPIO2,低电平亮(LOW=亮,HIGH=灭),外接LED需改引脚和电平。

总结

  1. 核心逻辑:ESP8266连WiFi→搭建Web服务器→手机浏览器发指令→ESP8266控制LED;
  2. 关键步骤:改WiFi密码→上传代码→查ESP8266的IP→手机访问IP/on/off;
  3. 全程10分钟搞定,不用装任何APP,浏览器直接控制。

如果想要「手机远程控制(不在家也能控)」或「微信小程序控制」的方案,我可以直接给你对应的代码和步骤。

相关推荐
开开心心就好1 天前
180套模板的图片艺术拼接实用工具
linux·服务器·网络·spring·智能手机·maven·excel
安卓机器1 天前
安卓玩机自做小工具------手机日志提取 查看 调试 分析工具
智能手机·提取日志
wanhengidc1 天前
云手机 算力终端应用
运维·服务器·网络·游戏·智能手机
半壶清水1 天前
如何将手机APP安装到windows上,让你在电脑大屏上用手机
windows·智能手机·app·电脑
Digitally2 天前
4 种实用方法:传音 Infinix 手机互传联系人
智能手机
lauo2 天前
从ThinkPad的10999元硬件堆料,看ibbot智慧体如何重新定义AI手机
人工智能·智能手机
wulechun2 天前
开源神器GuDong2003/xianyu-auto-reply-fix:闲鱼自动化客服管理系统深度解析与实战指南
智能手机
lauo2 天前
从华为“韬(τ)定律”到ibbot手机:AI原生时代的“τ”解法
华为·智能手机·ai-native
俊哥工具2 天前
无广告免费壁纸工具,手机电脑壁纸随心更换
python·智能手机·django·计算机外设·virtualenv·pygame
LCG元2 天前
ESPHome + HomeAssistant 搭建手机可控制的本地私有智能家居系统
网络·智能手机·智能家居