NodMCU 第二篇,web Server 控制LED灯

介绍

本篇利用NodMCU来做一个简易的web Server,并用web Server页面上的控件来控制LED灯。

#测试web server

首先还是来看一下例程吧。
这里使用的是


HelloServer例程
  • 打开例程,然后把SSID和password换你的,貌似不能设置中文的wifi名字,所以我很机智的使用了手机的热点。
Paste_Image.png
  • 上传程序
    上传成功后点开串口监视器,就会提示网页的ip地址
串口监视器内容
  • 在浏览器上输入对应的地址192.168.43.122:80
显示hello from esp8266!

例程成功了,

简易网页控制LED

<code>
#include <ESP8266WiFi.h>
const char* ssid = "xiangzi";
const char* password = "luoluoluo";
int ledPin = 13; // GPIO13
WiFiServer server(80);
void setup() {
Serial.begin(115200);
delay(10);
pinMode(ledPin, OUTPUT);
digitalWrite(ledPin, LOW);
// Connect to WiFi network
Serial.println();
Serial.println();
Serial.print("Connecting to ");
Serial.println(ssid);
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.print("Use this URL to connect: ");
Serial.print("http://");
Serial.print(WiFi.localIP());
Serial.println("/");
}
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");
while(!client.available()){
delay(1);
}
// Read the first line of the request
String request = client.readStringUntil('\r');
Serial.println(request);
client.flush();
// Match the request
int value = LOW;
if (request.indexOf("/LED=ON") != -1) {
digitalWrite(ledPin, HIGH);
value = HIGH;
}
if (request.indexOf("/LED=OFF") != -1) {
digitalWrite(ledPin, LOW);
value = LOW;
}
// Set ledPin according to the request
//digitalWrite(ledPin, value);
// Return the response
client.println("HTTP/1.1 200 OK");
client.println("Content-Type: text/html");
client.println(""); // do not forget this one
client.println("<!DOCTYPE HTML>");
client.println("<html>");
client.print("Led pin is now: ");
if(value == HIGH) {
client.print("On");
} else {
client.print("Off");
}
client.println("

");
client.println("Click <a href="/LED=ON">here</a> turn the LED on pin 2 ON
");
client.println("Click <a href="/LED=OFF">here</a> turn the LED on pin 2 OFF
");
client.println("</html>");
delay(1);
Serial.println("Client disonnected");
Serial.println("");
}
</code>
浏览器上输入IP地址,然后就可以显示界面

控制界面


高级的例程

把数据传给网页并显示

显示效果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容