奈何col 发表于 2020-3-26 20:18

为什么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

学习一下,我的舵机开门,偶尔会不在线,但有时一周也都不断

奈何col 发表于 2020-3-29 00:54

ebeeb 发表于 2020-3-28 22:46
学习一下,我的舵机开门,偶尔会不在线,但有时一周也都不断

4. 开发板供电不足   
解决办法:换电源 或 换USB口

可能是这个原因,舵机一定要独立供电

n1001 发表于 2020-3-29 07:33

补充一点就是网络环境

ebeeb 发表于 2020-3-29 09:20

奈何col 发表于 2020-3-29 00:54
4. 开发板供电不足   
解决办法:换电源 或 换USB口



我是从nodemcu板上接的5v

ebeeb 发表于 2020-3-29 09:21

试下单独供电

xue886 发表于 2020-4-8 20:01

esp01s直接插在继电器上控制灯泡,超过二十四小时待机app段就会显示设备离线,wifi是在线的,请问这是怎么回事?

奈何col 发表于 2020-4-8 23:09

xue886 发表于 2020-4-8 20:01
esp01s直接插在继电器上控制灯泡,超过二十四小时待机app段就会显示设备离线,wifi是在线的,请问这是怎么 ...

请看一楼

xue886 发表于 2020-4-9 15:08

奈何col 发表于 2020-4-8 23:09
请看一楼

继电器是5V的直接插在5V手机充电器,esp01s是插在继电器上的。不应该供电不足吧?

huanglecheg 发表于 2020-5-9 12:48

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不显示吗
页: [1] 2 3 4 5 6
查看完整版本: 为什么esp8266/esp32 wifi接入app显示设备离线