NEWS
MQTT Bluetooth BLE Anwesenheitserkennung mit ESP32
-
@amg_666
Wenn der esp32 nicht defekt ist, kann es ehrlich gesagt nur an den Einstellungen liegen. Ich habe problemlos 3 Stück geflashed und eingerichtet.
Sicher, dass die mqtt Einstellungen korrekt sind? IP und Port?
Kann morgen deine logs zu meinen vergleichen. Wo/Wie sind diese zu finden? -
@amg_666
Nimm mal die v2.0.25. Die v2.0.26 hat wahrscheinlich einen Bug.
Und automatische Updates deaktivieren. -
@maik-0 ich befürchte, dass der esp eine Macke hat. Mit der v2.0.25 komme ich nicht ins WLAN
[11:12:48]rst:0x1 (POWERON_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT) [11:12:48]configsip: 0, SPIWP:0xee [11:12:48]clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00 [11:12:48]mode:DIO, clock div:2 [11:12:48]load:0x3fff0018,len:4 [11:12:48]load:0x3fff001c,len:1044 [11:12:49]load:0x40078000,len:8896 [11:12:49]load:0x40080400,len:5828 [11:12:49]entry 0x400806ac [11:12:49]Connecting to WiFi (F0:08:D1:D8:0A:04)... [11:13:43]Connecting to WiFi SSID 'WLAN-772776'.........................................................................................................................................................................................................................................................................................................................................................................ets Jun 8 2016 00:22:57 [11:13:43] [11:13:43]rst:0x1 (POWERON_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT) [11:13:43]configsip: 0, SPIWP:0xee [11:13:44]clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00 [11:13:44]mode:DIO, clock div:2 [11:13:44]load:0x3fff0018,len:4 [11:13:44]load:0x3fff001c,len:1044 [11:13:44]load:0x40078000,len:8896 [11:13:44]load:0x40080400,len:5828 [11:13:44]entry 0x400806ac [11:13:44]Connecting to WiFi (F0:08:D1:D8:0A:04)... [11:14:44]Connecting to WiFi SSID 'WLAN-772776'................................................................................................................................................................................................................................................................................................................................................................................................................ failed. [11:14:44]Starting access point for configuration portal. [11:14:44]SSID: 'espresense-arbeitszimmer' [11:14:44]IP: 192.168.4.1 [11:16:19][E][WiFiClient.cpp:395] write(): fail on fd 56, errno: 104, "Connection reset by peer"
Die Einstellungen habe ich mehrfach überprüft, PAsswort für WLAN und mqtt-Einstellungen sind korrekt.
-
Ich muss nochmal fragen: Neue ESP bestellt, geflasht, läuft.
.Ich hab jetzt einen ESP im Netz, der erkennt auch mein Mi Band:Das Mi Band sehe ich jetzt auch in den Objekten, soweit alles gut. Wenn ich jetzt weitere BT devices habe, wie kann ich dann bestimmte devices explizit als "excluded" eintragen?
-
@amg_666
Exclude müsste von der Firmware espresense umgesetzt werden. Das ist bis jetzt noch nicht geschehen. Hatte mal ein Issue dazu auf github gesehen. Das solltest du verfolgen. -
@giuseppes sagte in MQTT Bluetooth BLE Anwesenheitserkennung mit ESP32:
Hatte mal ein Issue dazu auf github gesehen. Das solltest du verfolgen.
Danke für die Info.
ich hab jetzt nmoch ein Problem bzw eine Frage: Zum Testen habe ich 3 ESP geflasht und die in 3 Etagen angeschlossen. Final soll das mal so fein werden, dass ich den Raum einer Person (respektive des Devices) mitbekomme und dann individuell Licht/Musik etc steuern kann.
Samsung Smartphone: Quasselt regelmäßig mit den ESPs, ich werte die Entfernungen aus und die niedrigste Entfernung ist dann die Etage wo das Handy grade ist. Funktioniert ohne Probleme (na ja fast, die Entfernungsermittlung ist schon ziemlich ungenau, aber im großen und ganzen ok).
Fitnessband (mi 3 Band): Das hatte ich gestern getestet und auch da wurden die Datenpunkte der ESP regelmäßig upgedatet. Heute morgen war da "Funkstille" (im wahrsten Sinne des Wortes). Ich hab dann mal die ESP resettet, den mqtt Adapter neu gestartet und irgendwann liefs wieder gut. Jetzt ist wieder Stillstand und es wird nichts upgedatet.
Sind diese einfachen Fitnessbänder so unzuverlässig oder woran kann das liegen? Das Samsung ist fröhlich am aktualisieren... -
@amg_666
Ich verwendete zu Testzwecken mein miband5 bzw 6 und da gab es nie Probleme, wie du sie beschreibst. Grundsätzlich wurde immer gesendet. Über mehrere Wochen hatte ich teilweise getestet. -
Hallo zusammen,
ich bekomme es leider nicht hin den Sketch zu kompilieren. Bei Kompilieren erhalte ich immer folgende Fehlermeldung:
Arduino: 1.8.19 (Windows 10), Board: "ESP32 Dev Module, Disabled, Default 4MB with spiffs (1.2MB APP/1.5MB SPIFFS), 240MHz (WiFi/BT), QIO, 80MHz, 4MB (32Mb), 921600, None" C:\Users\Andy\Downloads\1603999752128-mqtt_anwesenheit_ota.ino\mqtt_anwesenheit_ota\mqtt_anwesenheit_ota.ino: In function 'void setup()': mqtt_anwesenheit_ota:226:8: error: 'class PubSubClient' has no member named 'set_server' mqtt.set_server(MQTT_server, MQTT_port); // MQTT Port einstellen ^ mqtt_anwesenheit_ota:228:29: error: no matching function for call to 'PubSubClient::connect(String&)' if (mqtt.connect(MQTT_Name)) ^ In file included from C:\Users\Andy\Downloads\1603999752128-mqtt_anwesenheit_ota.ino\mqtt_anwesenheit_ota\mqtt_anwesenheit_ota.ino:34:0: C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:112:12: note: candidate: boolean PubSubClient::connect(const char*) boolean connect(const char* id); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:112:12: note: no known conversion for argument 1 from 'String' to 'const char*' C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:113:12: note: candidate: boolean PubSubClient::connect(const char*, const char*, const char*) boolean connect(const char* id, const char* user, const char* pass); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:113:12: note: candidate expects 3 arguments, 1 provided C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:114:12: note: candidate: boolean PubSubClient::connect(const char*, const char*, uint8_t, boolean, const char*) boolean connect(const char* id, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:114:12: note: candidate expects 5 arguments, 1 provided C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:115:12: note: candidate: boolean PubSubClient::connect(const char*, const char*, const char*, const char*, uint8_t, boolean, const char*) boolean connect(const char* id, const char* user, const char* pass, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:115:12: note: candidate expects 7 arguments, 1 provided mqtt_anwesenheit_ota:231:18: error: 'MQTT' has not been declared mqtt.publish(MQTT::Publish("hallo", MQTT_Name).set_qos(QoS)); // im Topic hallo Präsenzmelder Name schreiben ^ C:\Users\Andy\Downloads\1603999752128-mqtt_anwesenheit_ota.ino\mqtt_anwesenheit_ota\mqtt_anwesenheit_ota.ino: In function 'void loop()': mqtt_anwesenheit_ota:271:16: error: 'MQTT' has not been declared mqtt.publish(MQTT::Publish(MQTT_Name, NachrichtJSON).set_qos(QoS)); // JSON per MQTT senden ^ mqtt_anwesenheit_ota:283:27: error: no matching function for call to 'PubSubClient::connect(String&)' mqtt.connect(MQTT_Name); ^ In file included from C:\Users\Andy\Downloads\1603999752128-mqtt_anwesenheit_ota.ino\mqtt_anwesenheit_ota\mqtt_anwesenheit_ota.ino:34:0: C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:112:12: note: candidate: boolean PubSubClient::connect(const char*) boolean connect(const char* id); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:112:12: note: no known conversion for argument 1 from 'String' to 'const char*' C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:113:12: note: candidate: boolean PubSubClient::connect(const char*, const char*, const char*) boolean connect(const char* id, const char* user, const char* pass); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:113:12: note: candidate expects 3 arguments, 1 provided C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:114:12: note: candidate: boolean PubSubClient::connect(const char*, const char*, uint8_t, boolean, const char*) boolean connect(const char* id, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:114:12: note: candidate expects 5 arguments, 1 provided C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:115:12: note: candidate: boolean PubSubClient::connect(const char*, const char*, const char*, const char*, uint8_t, boolean, const char*) boolean connect(const char* id, const char* user, const char* pass, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage); ^ C:\Users\Andy\Documents\Arduino\libraries\PubSubClient\src/PubSubClient.h:115:12: note: candidate expects 7 arguments, 1 provided Mehrere Bibliotheken wurden für "WiFi.h" gefunden Benutzt: C:\Users\Andy\AppData\Local\Arduino15\packages\esp32\hardware\esp32\1.0.5\libraries\WiFi Nicht benutzt: C:\Program Files (x86)\Arduino\libraries\WiFi exit status 1 'class PubSubClient' has no member named 'set_server'
Weiß jemand was ich hier machen kann?
-
@banis
Wozu überhaupt noch diesen Sketch verwenden? Espresense funktioniert ganz gut. -
@giuseppes Super vielen Dank das funktioniert mit Espresense ja mega einfach.
-
Welche Hardware nutzt ihr? Bzw welchen ESP32 sollte man denn kaufen? Bin von den verschiedenen Varianten auf Aliexpress etwas irritiert..
-
@grace13 Also bei mir läuft es mittlerweile ganz gut und ich benutze D1Mini von A-Z Delivery. Die sind da nicht sooo viel teurer als "beim Chinesen" und du hast kürzere Lieferzeiten und Garantie, bzw die sind eh sehr kulant.
Link auf die Homepage
Und wenn du dich da für den Newsletter einträgst kriegst du täglich irgendwelche Angebote, oft auch D1 Mini als Mehrfachpackung -
@grace13 said in MQTT Bluetooth BLE Anwesenheitserkennung mit ESP32:
Welche Hardware nutzt ihr? Bzw welchen ESP32 sollte man denn kaufen?
@amg_666 said in MQTT Bluetooth BLE Anwesenheitserkennung mit ESP32:
Also bei mir läuft es mittlerweile ganz gut und ich benutze D1Mini
Einziges Manko: Der gute D1 Mini hat einen esp82xx und keinen esp32. Sprich kein BLE an board und deswegen gänzlich ungeeignet für den gewünschten Einsatzzweck hier.
-
@opensourcenomad Sorry, dann hab ich den falschen verlinkt: "D1 Mini" Ausführung und auch in größerer Bauform
-
@amg_666 wurde mit ESPresense geflasht und funktioniert soweit, die Daten kommen am MQTT Adapter an. Ich hätte aber noch eine Frage.
Meine Bluetooth Mac Adresse vom Handy habe ich in "Known BLE mac addresses" eingetragen.
Im MQTT Adapter bekomme ich nun bestimmt über 20 Geräte angezeigt, allerdings ist keins mein Gerät. Wo liegt denn der Fehler? -
@grace13 said in MQTT Bluetooth BLE Anwesenheitserkennung mit ESP32:
Meine Bluetooth Mac Adresse vom Handy habe ich in "Known BLE mac addresses" eingetragen.
Mobilfunkdelefone neuerer Generationen, bzw. deren software randomisiert meist die mac Adressen der WLAN und Bluetooth interfaces (wenn diese passiv/nicht verbunden sind) um ein tracking für "Mitbewerber" zu erschweren.
Eventuell macht dir diese Funktion gerade das leben schwer?
-
@opensourcenomad hm okay, danke für die Info, dann werde ich es mal mit meiner galaxy watch versuchen.
-
@grace13 said in MQTT Bluetooth BLE Anwesenheitserkennung mit ESP32:
danke für die Info
Hätte ja Ansporn sein können kurz 20 Sekunden Internetrecherche zu betreiben und z.B. folgendes, für Androiden gültiges, Wissen zu erlangen:
For devices running Android 10 or higher, the framework uses randomized MAC address by default. Users can enable or disable MAC randomization for individual networks through an option in the Network details screen in Settings, as shown in Figure 1. If a user disables MAC randomization for a network, the framework uses the factory MAC address (globally unique address).
.
Quelle: https://source.android.com/devices/tech/connect/wifi-mac-randomization-behavior
..und wer genau liest sieht es geht nur um wifi
-
Hallo @giuseppes,
die Installation mit ESPresence funktioniert wirklich gut. Wie verarbeitest du die Werte aktuell weiter?
Nach langem hin und her denke ich, dass mir eine einfache Erkennung reichen würde, ob ein Gerät anwesend ist oder nicht.
LG
-
@spezialtrick
Ich habe das Thema Triangulation erstmal pausiert, weil mir die Werte zu stark streuen.
Ich habe ein esp32 im Schlafzimmer, eins in der Küche und eins neben der Couch im Wohnzimmer. Damit arbeite ich nun. Ohne viel drum herum, d.h. keine Skripte oder ähnliches, was noch viel verarbeitet. Wenn Distanz kleiner 2,5 Meter von einem esp32, dann bin ich genau da.