为什么esp8266/esp32 wifi接入app显示设备离线
blinker会自动获取设备状态,通常用户不需要做任何处理,但当你错误编写程序时,可能会造成状态反馈失败或者不及时的问题,这时blinker App就会显示该设备 离线。为了帮助开发者更好的调试程序,这里我对blinker app的判断逻辑,及调试方法做一些讲解。blinker App如何判断设备是否在线?
blinker App在 App打开时、进入设备页面时、在设备页面中每隔一定时间 会向设备发送心跳请求,内容为{"get":"state"}。
设备收到请求后,会返回{"state":"online"},app接收到这个返回,即会显示设备在线。
app中显示设备离线,并不等于设备没有连接上mqtt,但可以肯定的是:你的设备没有响应或者错误响应了app发出的心跳请求。
哪些情况可能造成显示离线?
1. 程序没有成功上传到开发板
解决办法:重新上传,上传后打开串口监视器,确认程序正确运行
2. 程序中没有设置正确的ssid和密码,导致没有连接上网络
解决办法:设置后再重新上传程序,上传后打开串口监视器,确认程序正确运行
3. 程序错误,导致程序运行不正确
解决办法:按文档安装相关依赖,先使用并理解blinker例程,再自由发挥
4. 开发板供电不足
解决办法:换电源、换USB口 或者 在vcc和gnd间并电容
对于程序错误造成的离线,如何调试?
在程序初始化时添加debugAll,获取更详细的调试信息。
arduino程序如下:
void setup()
{
Serial.begin(115200);
BLINKER_DEBUG.stream(Serial);
BLINKER_DEBUG.debugAll();
}
然后通过串口调试,查看设备是否正确接收到{"get":"state"}并响应{"state":"online"}
如何修复错误?
笨办法:逐句注释掉自己写的代码,看看是那一句造成的反馈错误
正常的办法:理解blinker程序逻辑,通过调试信息,分析程序哪里造成了反馈错误或不及时
学习一下,我的舵机开门,偶尔会不在线,但有时一周也都不断 ebeeb 发表于 2020-3-28 22:46
学习一下,我的舵机开门,偶尔会不在线,但有时一周也都不断
4. 开发板供电不足
解决办法:换电源 或 换USB口
可能是这个原因,舵机一定要独立供电 补充一点就是网络环境 奈何col 发表于 2020-3-29 00:54
4. 开发板供电不足
解决办法:换电源 或 换USB口
我是从nodemcu板上接的5v 试下单独供电 esp01s直接插在继电器上控制灯泡,超过二十四小时待机app段就会显示设备离线,wifi是在线的,请问这是怎么回事? xue886 发表于 2020-4-8 20:01
esp01s直接插在继电器上控制灯泡,超过二十四小时待机app段就会显示设备离线,wifi是在线的,请问这是怎么 ...
请看一楼 奈何col 发表于 2020-4-8 23:09
请看一楼
继电器是5V的直接插在5V手机充电器,esp01s是插在继电器上的。不应该供电不足吧? csum 0xd0
v3d128e5c
~ld
ets Jan8 2013,rst cause:4, boot mode:(3,6)
wdt reset
load 0x4010f000, len 1392, room 16
tail 0
chksum 0xd0
csum 0xd0
v3d128e5c
~ld
ets Jan8 2013,rst cause:4, boot mode:(3,6)
wdt reset
load 0x4010f000, len 1392, room 16
tail 0
chksum 0xd0
csum 0xd0
v3d128e5c
~ld
Opening port
Port open
��
__ __ __
/\ \ /\ \ __ /\ \ v0.3.4
\ \ \___ \ \ \/\_\ ___\ \ \/'\ __ _ __
\ \ '__`\\ \ \ \/\ \ /' _ `\ \ , < /'__`\/\`'__\
\ \ \L\ \\ \ \_\ \ \/\ \/\ \ \ \\`\ /\__/\ \ \./
\ \_,__/ \ \__\\ \_\ \_\ \_\ \_\ \_\ \____\\ \_\
\/___/ \/__/ \/_/\/_/\/_/\/_/\/_/\/____/ \/_/
To better use blinker with your IoT project!
Download latest blinker library here!
=> https://github.com/blinker-iot/blinker-library
Connecting to MIWIFI
ESP8266_MQTT initialized...
===========================================================
================== Blinker Timer loaded! ==================
Warning!EEPROM address 1536-2431 is used for Blinker Timer!
============= DON'T USE THESE EEPROM ADDRESS! =============
===========================================================
WiFi Connected.
IP Address:
192.168.1.34
Freeheap: 10280
mDNS responder started
webSocket_MQTT server started
ws://3F28F7669O8UPBBGSZBHKVM2.local:81
Connecting to MQTT...
MQTT Connected!
Freeheap: 9952
=======================================================
=========== Blinker Auto Control mode init! ===========
Warning!EEPROM address 0-1279 is used for Auto Control!
=========== DON'T USE THESE EEPROM ADDRESS! ===========
=======================================================
Port closed
Opening port
Port open
ets Jan8 2013,rst cause:4, boot mode:(3,6)
wdt reset
load 0x4010f000, len 1392, room 16
tail 0
chksum 0xd0
csum 0xd0
v3d128e5c
~ld
大佬可以帮忙看看为什么连上了服务器但是app不显示吗