Hallo zusammen, beim Aufbau einer Server-Client-Wifi-Verbindung stelle ich ein Problem fest, welches ich nicht gelöst bekomme. Ich habe mehrere Sensoren in meinem Netzwerk, die Messwerte an den Server (ebenfalls ESP8266-12) senden. dabei ist folgender Effekt zu beobachten: die erste Übertragung eines Wertes erfolgt normal, wird anschliessend der Wert geändert und erneut übertragen erfolgt am Server (serielle Ausgabe) 19 mal die Ausgabe des alten Wertes im Abstand von jeweils 5 sec. Dann erscheint manchmal der neue Werte einmal. Eine neue Übertragung eines Wertes wiederholt o.g. Ablauf erneut. Gleiches Verhalten ist sowohl bei Einzelmodul ESP8266-12, als auch mit NodeMCU feststellbar. Hat jemand dazu eine Idee? Codeauszug: void check_client(){ WiFiClient client=server.available(); if (!client) { return; } String req ="+IPD,0,0:" + client.readString(); Serial.println(req); client.flush(); client.stop(); req=""; } Der Aufruf der Routine erfolgt in der Loop-Schleife;
Fehler in Zeile 42: client.flush() macht etwas anderes, als du denkst. Nee, ernsthaft: So wird das nichts, das ist Stochern im Nebel. 1) Schau dir den tatsächlichen Netzwerkverkehr an (mit Tools wie tcpdump oder wireshark). 2) Verwende telnet oder netcat als Client und Server. Dann weißt du, ob das Problem beim Client oder beim Server liegt. Dann baust du ein Minimalbeispiel, das den Fehler auch noch zeigt, und stellst es hier vollständig (!) ein (als Anhang). Danke, Arno
Irgendwie fehlt da was oder?
1 | WiFiClient client = server.available(); |
2 | if (client){ |
3 | while (client.connected()){ |
4 | if (client.available()){ |
5 | String line = client.readStringUntil('\r'); |
6 | Serial.print(line); |
7 | |
8 | }
|
9 | }
|
10 | }
|
11 | |
12 | client.stop(); |
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.