【问题标题】:nodemcu ESP8266 webserver times outnodemcu ESP8266 网络服务器超时
【发布时间】:2017-01-30 02:09:37
【问题描述】:

我对使用 NodeMCU ESP8266 12E 模块非常陌生。我在 arduino-IDE 上使用它。我有一个简单的草图,可以通过本地网络控制 LED。当我在设备上运行服务器时它工作正常。但是,大约 10 分钟后,浏览器无法再与设备通信,似乎服务器已关闭。我尝试在this video 之后刷新模块,因为我读到我应该尝试更新固件。我闪到 nodemcu_float_0.9.6-dev_20150704。问题依然存在。

这里是代码。

#include <ESP8266WiFi.h>
const char* ssid = "mynetwork";
const char* password = "mypassword";
int ledPin = 13;
WiFiServer server(80);
void setup() {
  Serial.begin(115200);
  delay(10);
  pinMode(ledPin, OUTPUT);
  digitalWrite(ledPin, LOW);
  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");
  server.begin();
  Serial.println("Server started");
  Serial.print("Use this URL to connect: ");
  Serial.print("http://");
  Serial.print(WiFi.localIP());
  Serial.println("/");
}
void loop() {
  WiFiClient client = server.available();
  if (!client) {
    return;
  }
  Serial.println("new client");
  while(!client.available()){
    delay(1);
  }
  String request = client.readStringUntil('\r');
  Serial.println(request);
  client.flush();
  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;
  }
// 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("<br><br>");
  client.println("<a href=\"/LED=ON\"\"><button>Turn On </button></a>");
  client.println("<a href=\"/LED=OFF\"\"><button>Turn Off </button></a><br />");  
  client.println("</html>");

  delay(1);
  Serial.println("Client disonnected");
  Serial.println("");
}

为什么会超时或突然关闭?我希望服务器 24/7 运行,我的计划是构建一个 android 应用程序来通过互联网打开/关闭风扇、灯、泵等。

请指教。

【问题讨论】:

  • 0.9.6 旧且有缺陷。使用来自nodemcu-build.com的固件
  • 感谢您的链接...选择模块是一项艰巨的任务,特别是因为我不清楚所有模块。
  • 刷入 NodeMCU 固件对您没有任何好处 - 当您使用 Arduino SDK 时,您并没有使用他们的固件。事实上,每次你刷新上面的代码时,它都会擦除芯片上的任何固件。

标签: arduino esp8266 arduino-ide nodemcu arduino-esp8266


【解决方案1】:

您的代码仅在运行最终延迟/串行打印所需的持续时间内将 WiFiClient 保留在范围内 - 之后,WiFiClient 将被销毁,并且无法保证任何数据都可以到达客户端。现在,前十分钟这对您来说似乎工作得很好,但是,我不希望总是这样。

此外,您可以启用调试日志记录并在此处发布结果吗? SDK 有函数Serial.setDebugOutput(true/false) 来设置它。它将包括可能有帮助的其他信息。

最后,您是否考虑过使用 ESP Arduino SDK 中包含的 ESP8266WebServer 类?它已经实现了一个经过良好测试且功能强大的 Web 服务器,这似乎正是您想要的,并且可以避免您在开发自己的服务器时遇到挫折。

【讨论】:

    猜你喜欢
    • 2018-09-08
    • 2011-06-30
    • 2018-08-16
    • 2017-01-27
    • 1970-01-01
    • 2023-03-11
    • 1970-01-01
    • 2021-07-25
    • 1970-01-01
    相关资源
    最近更新 更多