mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-26 14:12:16 +03:00
Избавляемся от постоянной ошибки Udp packet invalid
Возникала по причине получения пакета из другой группы Плюс добавилась проверка формата Json и наличия поля wg
This commit is contained in:
@@ -37,12 +37,16 @@ void asyncUdpInit() {
|
||||
// Serial.print(", Data: ");
|
||||
// Serial.write(packet.data(), packet.length());
|
||||
String data = uint8tToString(packet.data(), packet.length());
|
||||
// Serial.println(data);
|
||||
if (udpPacketValidation(data)) {
|
||||
SerialPrint("i", F("UDP"), "IP: " + packet.remoteIP().toString() + ":" + String(packet.remotePort()));
|
||||
// Serial.println(data);
|
||||
jsonMergeArrays(devListHeapJson, data);
|
||||
// Serial.println(devListHeapJson);
|
||||
String remoteWorkgroup = "";
|
||||
data.replace("[", "");
|
||||
data.replace("]", "");
|
||||
if (jsonRead(data, F("wg"), remoteWorkgroup)) { // проверяем чтоб полученный формат был Json и заодно вытягиваем имя группы
|
||||
String loacalWorkgroup = "";
|
||||
jsonRead(settingsFlashJson, F("wg"), loacalWorkgroup);
|
||||
if (remoteWorkgroup == loacalWorkgroup) {
|
||||
SerialPrint("i", F("UDP"), "IP: " + packet.remoteIP().toString() + ":" + String(packet.remotePort()));
|
||||
jsonMergeArrays(devListHeapJson, data);
|
||||
}
|
||||
} else {
|
||||
SerialPrint("E", F("UDP"), F("Udp packet invalid"));
|
||||
}
|
||||
@@ -68,16 +72,6 @@ void asyncUdpInit() {
|
||||
SerialPrint("i", F("UDP"), F("Udp Init"));
|
||||
}
|
||||
|
||||
bool udpPacketValidation(String& data) {
|
||||
// SerialPrint("i", F("UDP"), data);
|
||||
String workgroup = jsonReadStr(settingsFlashJson, "wg");
|
||||
if (workgroup != "" && data.indexOf(workgroup) != -1) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
void jsonMergeArrays(String& existJson, String& incJson) {
|
||||
DynamicJsonDocument incJsonDoc(1024);
|
||||
DeserializationError incJsonError = deserializeJson(incJsonDoc, incJson);
|
||||
|
||||
Reference in New Issue
Block a user