Arduino+ESP8266wifi+html实现控制小灯

本文介绍了使用Arduino、ESP8266wifi和html实现小灯控制的方法。包括esp8266wifi灯控的连线,如继电器in口接D4口;强调串口打印要选对波特率;还说明了连接wifi并访问网页来操作小灯,同时给出了Arduino IDE和html代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Arduino+ESP8266wifi+html实现控制小灯

esp8266wifi灯控连线

继电器in口接D4口
在这里插入图片描述

串口打印(选择正确的波特率,我的第一行就是教训)

串口输出数据

连接wifi,访问网页实现操作

在这里插入图片描述

代码

Arduino IDE代码 (为了方便我直接基于helloserver进行了修改)

#include <ESP8266WiFi.h>
#include <WiFiClient.h>
#include <ESP8266WebServer.h>
#include <ESP8266mDNS.h>

const char* ssid = "wifi名称";               
const char* password = "wifi密码";
//压缩后的html代码
String html = "<!DOCTYPE html><html> <head>    <meta charset=\"utf-8\" />    <title></title> </head> <body>  <a href=\"./pin?light=on\"><input type=\"button\" value=\"&#x5F00;&#x706F;\"></a>   <a href=\"./pin?light=off\"><input type=\"button\" value=\"&#x5173;&#x706F;\"></a>    </body></html>";

//主要添加了这个函数
void pin(){
  if(server.arg("light")=="on"{
  digitalWrite(D4, LOW);         //低电平有效
  server.send(200, "text/html",html);
  }else if(server.arg("light"=="off"){
    digitalWrite(D4, HIGH);     //di'dian'ping
  server.send(200, "text/html",html);
  }
  }
  
ESP8266WebServer server(80);

const int led = 13;

void handleRoot() {
  digitalWrite(led, 1);
  server.send(200, "text/html",html);
  digitalWrite(led, 0);
}

void handleNotFound(){
  digitalWrite(led, 1);
  String message = "File Not Found\n\n";
  message += "URI: ";
  message += server.uri();
  message += "\nMethod: ";
  message += (server.method() == HTTP_GET)?"GET":"POST";
  message += "\nArguments: ";
  message += server.args();
  message += "\n";
  for (uint8_t i=0; i<server.args(); i++){
    message += " " + server.argName(i) + ": " + server.arg(i) + "\n";
  }
  server.send(404, "text/plain", message);
  digitalWrite(led, 0);
}

void setup(void){
  pinMode(D4, OUTPUT);  //初始化D4引脚
  digitalWrite(led, 0);
  Serial.begin(115200);
  WiFi.begin(ssid, password);
  Serial.println("");

  // Wait for connection
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  Serial.println("");
  Serial.print("Connected to ");
  Serial.println(ssid);
  Serial.print("IP address: ");  //打印访问的地址
  Serial.println(WiFi.localIP());

  if (MDNS.begin("esp8266")) {
    Serial.println("MDNS responder started");
  }

  server.on("/", handleRoot);
  server.on("/pin", HTTP_GET, pin);

  server.on("/inline", [](){
    server.send(200, "text/plain", "this works as well");
  });

  server.onNotFound(handleNotFound);

  server.begin();
  Serial.println("HTTP server started");
}

void loop(void){
  server.handleClient();
}

html代码(压缩时需要在双引号前加“\”,或者用单引号替换)

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>ControlPage</title>
	</head>
	<body>
		<a href="./pin?light = on"><input type="开灯"></a>
		<a href="./pin?light = "><input type="关灯"></a>
	</body>
</html>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值