ESP8266 не может публиковать более длинные данные по теме mqtt
Я использую esp8266 и Arduino IDE для программирования. Когда я пытаюсь опубликовать данные JSON по теме MQTT из esp8266 по сети Wi-Fi, он работает для приведенного ниже кода.
void reportToServer(){
String payload = "{\"DeviceID\":"+String(devices[0].getDeviceID())+","
"\"DeviceName\":"+"\""+String(devices[0].getDeviceName())+"\""+","
"\"Counter\":"+String(devices[0].getSwitchOnTime())+","
"\"Status\":"+String(devices[0].getStatus())+"};
Serial.println(payload.c_str());
client.publish("esp/test",payload.c_str());
Serial.println("Reported to server");
}
но когда я пытаюсь опубликовать код, как показано ниже, данные не принимаются клиентом графического интерфейса MQTT.Fx -
void reportToServer(){
String payload = String payload = "{{\"DeviceID\":"+String(devices[0].getDeviceID())+","
"\"DeviceName\":"+"\""+String(devices[0].getDeviceName())+"\""+","
"\"Counter\":"+String(devices[0].getSwitchOnTime())+","
"\"Status\":"+String(devices[0].getStatus())+"},"+
"{\"DeviceID\":"+String(devices[1].getDeviceID())+","
"\"DeviceName\":"+"\""+String(devices[1].getDeviceName())+"\""+","
"\"Counter\":"+String(devices[1].getSwitchOnTime())+","
"\"Status\":"+String(devices[1].getStatus())+"}}";
+"{\"DeviceID\":"+String(devices[2].getDeviceID())+","
"\"DeviceName\":"+"\""+String(devices[2].getDeviceName())+"\""+","
"\"Counter\":"+String(devices[2].getSwitchOnTime())+","
"\"Status\":"+String(devices[2].getStatus())+"},"
+"{\"DeviceID\":"+String(devices[3].getDeviceID())+","
"\"DeviceName\":"+"\""+String(devices[3].getDeviceName())+"\""+","
"\"Counter\":"+String(devices[3].getSwitchOnTime())+","
"\"Status\":"+String(devices[3].getStatus())+"},"
+"{\"DeviceID\":"+String(devices[4].getDeviceID())+","
"\"DeviceName\":"+"\""+String(devices[4].getDeviceName())+"\""+","
"\"Counter\":"+String(devices[4].getSwitchOnTime())+","
"\"Status\":"+String(devices[4].getStatus())+"},"
+"{\"DeviceID\":"+String(devices[5].getDeviceID())+","
"\"DeviceName\":"+"\""+String(devices[5].getDeviceName())+"\""+","
"\"Counter\":"+String(devices[5].getSwitchOnTime())+","
"\"Status\":"+String(devices[5].getStatus())+"}}";
Serial.println(payload.c_str());
client.publish("esp/test",payload.c_str());
Serial.println("Reported to server");
}
1 ответ
Решение
Как сказано в комментариях
Полезная нагрузка слишком велика. Решение - использоватьpublish_p()
метод.