繁体   English   中英

ESP8266 异常(三)

[英]ESP8266 exception (3)

我使用 ESP8266 作为带有 Arduino IDE 的网络服务器。 ESP8266 提供 HTML 网页并在接收 POST 请求时更改 GPIO 输出。 下面的代码工作正常。

  • Arduino IDE:1.8.11 适用于 Linux
  • ESP8266:ESP-01
  • ESP8266 内核版本:2.6.2

ps index.h 只是一个包含PAGE_INDEX的文件,它是 HTML 页面的字符串。

#include <ESP8266WiFi.h>
#include <ESP8266WebServer.h>
#include "index.h"

#define OUT_PIN1 2
#define OUT_PIN2 0

const char ssid[] = "********";
const char pass[] = "********";

ESP8266WebServer server(80); // Run a web server on port 80

// handaling the request of main page
void rootRouter() {
  server.send (200, "text/html", PAGE_INDEX );
}

void setup() {
  pinMode(OUT_PIN1, OUTPUT);
  pinMode(OUT_PIN2, OUTPUT);
  Serial.begin(115200);

  // Connecting to wifi
  WiFi.begin(ssid, pass);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  Serial.println("");
  Serial.print("WiFi connected, IP: ");
  Serial.println(WiFi.localIP());  // print the ip

  // the main page
  server.on ( "/", rootRouter);
  // page for switch 1
  server.on ("/sw1", []() {
     String state = server.arg("led");
     if (state == "ON") {
         digitalWrite(OUT_PIN1, HIGH);
     } else if (state == "OFF") {
         digitalWrite(OUT_PIN1, LOW);
     }

     Serial.print("OUT_PIN1: ");
     Serial.println(state);
  });
  // page for switch 2
  server.on ("/sw2", []() {
     String state = server.arg("led");
     if (state == "ON") {
         digitalWrite(OUT_PIN2, HIGH);
     } else if (state == "OFF") {
         digitalWrite(OUT_PIN2, LOW);
     }

     Serial.print("OUT_PIN2: ");
     Serial.println(state);
  });
  // For page not found
  server.onNotFound([](){
    server.send(404, "text/plain", "404 NOT found!");
  });

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

void loop() {
    server.handleClient(); // handaling requests
}

但是,当我修改代码的某些部分时。 我得到了例外(3)。 我在下面的代码中修改的内容:

  1. 再添加一页/sw以更改两个 GPIO 的输出。
  2. 删除一些Serial.print()
  3. 获取 POST 请求时发送 204 响应。

我修改的代码:

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

#include "index.h"

#define OUT_PIN1 2
#define OUT_PIN2 0

const char ssid[] = "********";
const char pass[] = "********";

ESP8266WebServer server(80);  // Run a web server on port 80

// handaling the request of main page
void rootRouter() { server.send(200, "text/html", PAGE_INDEX); }

void setup() {
  pinMode(OUT_PIN1, OUTPUT);
  pinMode(OUT_PIN2, OUTPUT);
  Serial.begin(115200);

  // Connecting to wifi
  WiFi.begin(ssid, pass);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  Serial.println("");
  Serial.print("WiFi connected, IP: ");
  Serial.println(WiFi.localIP());  // print the ip

  // the main page
  server.on("/", rootRouter);

  // This is the page I add
  server.on("/sw", []() {
    String state = server.arg("led");
    if (state == "ON") {
      digitalWrite(OUT_PIN1, HIGH);
      digitalWrite(OUT_PIN2, HIGH);
    } else if (state == "OFF") {
      digitalWrite(OUT_PIN1, LOW);
      digitalWrite(OUT_PIN2, LOW);
    }
    server.send(204);
  });
  // page for switch 1
  server.on("/sw1", []() {
    String state = server.arg("led");
    if (state == "ON") {
      digitalWrite(OUT_PIN1, HIGH);
    } else if (state == "OFF") {
      digitalWrite(OUT_PIN1, LOW);
    }
    server.send(204);
  });
  // page for switch 2
  server.on("/sw2", []() {
    String state = server.arg("led");
    if (state == "ON") {
      digitalWrite(OUT_PIN2, HIGH);
    } else if (state == "OFF") {
      digitalWrite(OUT_PIN2, LOW);
    }
    server.send(204);
  });
  // For page not found
  server.onNotFound([]() { server.send(404, "text/plain", "404 NOT found!"); });

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

void loop() {
  server.handleClient();  // handaling requests
}

错误:

Exception (3):
epc1=0x40100794 epc2=0x00000000 epc3=0x00000000 excvaddr=0x4006ead9 depc=0x00000000

>>>stack>>>

ctx: cont
sp: 3ffffb50 end: 3fffffc0 offset: 01a0
3ffffcf0:  00000000 feefeffe feefeffe feefeffe  
3ffffd00:  401027d4 00080000 feefeffe 3ffffeb0  
3ffffd10:  0000049c 0000049c 00000020 40100984  
3ffffd20:  feefeffe 2c9f0300 4000050c 3fffc278  
3ffffd30:  00000000 400042db 000000fe 40100bdc  
3ffffd40:  40004b31 00001000 000000fe 401002f8  
3ffffd50:  40105c74 00000001 3ffef850 40232b29  
3ffffd60:  40105e31 40232c13 3ffef854 0000049c  
3ffffd70:  000000fd 3ffffeb0 3ffef854 40232bf6  
3ffffd80:  ffffff01 55aa55aa 00000011 00000020  
3ffffd90:  00000020 0000006d 0000006d aa55aa55  
3ffffda0:  000000ff 402330f6 3ffef854 3ffef854  
3ffffdb0:  000000ff 000001ae 000001ae 401006c4  
3ffffdc0:  40105e31 00000001 3ffef864 40233316  
3ffffdd0:  00000005 3ffef854 000000ff 3ffffeb0  
3ffffde0:  3ffffed0 3ffef88b 00000011 00000020  
3ffffdf0:  3ffef914 3fffff11 00000001 402333c6  
3ffffe00:  3ffffeb0 4023f750 00000000 00000008  
3ffffe10:  3ffefc54 3ffffed0 3fff5b8c 40233395  
3ffffe20:  3ffef854 402333fc 3ffe84cc 3ffe868e  
3ffffe30:  40204302 3ffe868e 3ffe8685 40204257  
3ffffe40:  69676e65 645f656e 5f6d726f 47342e32  
3ffffe50:  40007a48 feefeffe feefeffe feefeffe  
3ffffe60:  30323230 24234021 3ffef700 40207a07  
3ffffe70:  0000001c 0001c200 00000000 00000000  
3ffffe80:  00000003 40207bc9 ffffffff 00000001  
3ffffe90:  feefeffe 00000001 3ffee4a4 3ffee520  
3ffffea0:  1b327800 fea4bec5 feefeffe 00000100  
3ffffeb0:  69676e65 645f656e 5f6d726f 47342e32  
3ffffec0:  40007a48 feefeffe feefeffe feefeffe  
3ffffed0:  30323230 24234021 3ffef700 40207afb  
3ffffee0:  0000001c 0001c200 00000000 00000000  
3ffffef0:  00000003 40207cbd ffffffff 00000001  
3fffff00:  feefeffe 00000001 3ffee494 3ffee510  
3fffff10:  00000000 00000001 3ffee481 00000002  
3fffff20:  00000004 00000000 3ffee45c 00000001  
3fffff30:  0001c200 0000001c 00000000 3ffee510  
3fffff40:  3ffee494 00000000 3ffee45c 40201b1c  
3fffff50:  feefeffe feefeffe feefeffe feefeffe  
3fffff60:  feefeffe feefeffe feefeffe feefeffe  
3fffff70:  feefeffe feefeffe feefeffe feefeffe  
3fffff80:  feefeffe feefeffe feefeffe feefeffe  
3fffff90:  feefeffe feefeffe feefeffe 3ffee510  
3fffffa0:  3fffdad0 00000000 3ffee4d0 40206a00  
3fffffb0:  feefeffe feefeffe 3ffe84e8 40100c11  
<<<stack<<<

 ets Jan  8 2013,rst cause:4, boot mode:(1,6)

wdt reset

 ets Jan  8 2013,rst cause:4, boot mode:(1,6)

wdt reset

我还尝试只添加一个我只提到一次的功能,但总是出现异常 (3) 错误。

调试的一般步骤:
用固定的字符数组替换你的 String 类。
向浏览器发送一个简单的 200 响应 - 这最适合测试

 server.send(200,"text/plain","");

添加串行打印以进行调试和
如果您只想处理 POST 确保它与

server.on("/sw", HTTP_POST,  []() 
 Serial.println("Debug: /sw started");
 ... do something ...
 Serial.println("Debug: /sw finished");
 )

分析发送的内容以及浏览器中通过 Web 开发人员控制台接收的内容(如果有的话)。
如需进一步帮助,请列出您的环境 ArduinoIDE 1.8.12 和 esp8266 内核版本(最新为 2020 年 3 月 20 日版本 2.6.2),以及发送和接收的请求标头。
另一个提示:异常 3 是越界写入,到目前为止(请参阅问题 #1997 - 已关闭但尚未完全解决 - 在 esp8266 存储库中)所以提到您将索引页存储在闪存中,请尝试完全删除:
在 Arduino IDE 中:一旦刷新草图,将工具/擦除闪存更改为“所有闪存内容”。 然后将其设置回“仅草图”阅读问题以了解更多原因和可能的解决方案。

为了让选民失望 - 离开 - 至少 - 评论你会做什么。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM