ESP8266 控制开关
控制 开关 Esp8266
2023-09-11 14:21:10 时间
以ESP8266为服务端,当用户的访问设备与ESP8266在同一个Wi-Fi下时,可以通过ESP8266的IP地址来访问控制灯光开关的页面。
使用方法:
第一步、将下面的代码修改过Wi-Fi名称和密码后烧录到ESP中;
第二步、打开串口调试工具,查看该ESP的IP地址;
第三步、访问 IP地址/index.html 页面,通过页面的两个按钮控制灯的开关;
代码如下:
#include <ESP8266WiFi.h> const char* ssid = "Wi-Fi名称"; const char* password = "Wi-Fi密码"; WiFiServer server(80); void setup() { pinMode(D4, OUTPUT); Serial.begin(115200); delay(10); WiFi.begin(ssid, password); while (WiFi.status() != WL_CONNECTED) { delay(500); Serial.print("."); } Serial.println(""); Serial.println("WiFi connected"); // Start the server server.begin(); Serial.println("Server started"); // Print the IP address Serial.println(WiFi.localIP()); } void loop() { // Check if a client has connected WiFiClient client = server.available(); if (!client) { return; } // Wait until the client sends some data Serial.println("new client connected"); while(!client.available()){ delay(1); } // Read the first line of the request String req = client.readStringUntil('\r'); Serial.println(req); client.flush(); // Prepare the response String page = "HTTP/1.1 200 OK\r\nContent-Type: text/html\r\n\r\n<!DOCTYPE HTML>\r\n<html>\r\n<head>"; page += "<meta charset='utf-8'>"; page += "\r\n<link href='https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css' rel='stylesheet'>"; page += "\r\n<script src='https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.js'></script>"; page += "\r\n</head>\r\n<body style='padding:10px'>"; page += "\r\n<button class='btn btn-success zp-open' style='width:100%; height:100px;'>开启</button><br>"; page += "\r\n<button class='btn zp-close' style='width:100%; margin-top:10px; height:100px;'>关闭</button>"; page += "\r\n<script>\r\n"; page += "$('.zp-open').click(function(){$.post('/gpio/1', {}, function(){alert('开启成功');})});"; page += "\r\n"; page += "$('.zp-close').click(function(){$.post('/gpio/0', {}, function(){alert('关闭成功');})});"; page += "\r\n</script>"; page += "\r\n</body>\r\n</html>\n"; String json = "HTTP/1.1 200 OK\r\nContent-Type: text/html\r\n\r\n success"; // Match the request int val; if (req.indexOf("/gpio/0") != -1) { val = 0; } else if (req.indexOf("/gpio/1") != -1) { val = 1; } else if (req.indexOf("/index.html") != -1) { client.print(page); return; } else { Serial.println("invalid request"); client.stop(); return; } digitalWrite(D4, val); client.print(json); delay(1); }
相关文章
- 让研究生给你讲讲GPS越野车模运动控制
- jenkins学习笔记第十六篇 jenkins权限控制
- Sentinel的快速入门,三分钟带你体验流量控制
- python - 拼接,python流程控制
- vue 3.0 项目搭建移动端 (六) 命名路由同级控制
- MacOS新功能“通用控制”,多台设备操作互联太方便了!
- 《Swift开发实战》——第2章,第2.3节流程控制
- TCP的可靠传输机制(简单好理解:分段与流,滑窗,连接,流量控制,重新发送,堵塞控制)
- Flash又曝出严重漏洞:允许攻击者控制Mac
- 浅析css性能优化font-display的使用:控制字体加载和替换
- Proteus——开关控制流水灯的实现
- 【正点原子FPGA连载】第九章按键控制LED灯实验 -摘自【正点原子】新起点之FPGA开发指南_V2.1
- 板厂阻抗控制5%为什么那么难?这个因素就可能把误差占满了!
- Web Service学习-CXF开发Web Service的权限控制(二)
- 物联网肮脏的小秘密:并不完全受你控制
- redis 控制调用频率
- 【项目实战】——USB双路继电器电脑控制灯的开关(Python)
- 手把手一步步实现基于vvvvv实现自由管理系统,包含用户的增删改查、限速、流量控制、登录终端数量控制、自动部署多节点链路、日志统计等等,附自动化脚本和源码(四)
- 控制旋转和移动到目标物体