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,浏览器直接控制。

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

相关推荐
西瓜程序猿12 小时前
使用手机如何将纸质礼薄转换为电子礼薄?
测试工具·智能手机·创业创新·记了么·电子礼薄·份子钱
AI英德西牛仔16 小时前
手机怎么把AI对话导出
人工智能·ai·智能手机·豆包·deepseek·ds随心转
计算机毕设vx_bysj68691 天前
【免费领源码】77196基于java的手机银行app管理系统的设计与实现 计算机毕业设计项目推荐上万套实战教程JAVA,node.js,C++、python、大屏数据可视化
java·mysql·智能手机·课程设计
私人珍藏库1 天前
【Android】一键硬核锁手机
android·智能手机·app·工具·软件
唔662 天前
flutter TextTheme 手机端适配验证
flutter·智能手机
私人珍藏库2 天前
【Android】GameNative 0.9.0 [特殊字符] 手机畅玩Steam游戏
android·游戏·智能手机·app·工具·软件·多功能
wanhengidc2 天前
云手机搬砖安全吗
大数据·运维·服务器·安全·游戏·智能手机
wanhengidc2 天前
服务器管理器的作用有哪些?
运维·服务器·网络·安全·游戏·智能手机
应用市场2 天前
手机卫星通信原理深度解析:从物理层到协议栈的全面技术剖析
智能手机
皮皮虾12343 天前
六边云手机 VS VMOS 云手机 VS 红手指云手机哪个好?
智能手机