Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
cjson
MQTT
MQTTSerialize_publish len: -2
发布于 2024-07-09 11:50:03 浏览:428
订阅该版
使用pahomqtt,系统运行后开启mqtt,串口接收数据解析正确后发送tx7_mq的消息队列,在mqtt的publish线程中接收到该消息队列后生成json格式数据,然后通过mqtt进行发布,当json数据比较少时,可以正常发送,当数据比较多时,发送的主题toplic会变成很多的乱码“#”,导致 MQTTSerialize_publish len: -2  线程堆栈4096  mqtt的publish大小是4096  问题就出现在当json数据较多时,toplic就会变成乱码,导致长度计算出错,应该怎么解决这个问题呢 MQTT 的启动和初始化程序 ```c static void mq_start(void) { /* init condata param by using MQTTPacket_connectData_initializer */ MQTTPacket_connectData condata = MQTTPacket_connectData_initializer; rt_memset(&client, 0, sizeof(MQTTClient)); struct netif *netif = netif_list; // 获取网络接口列表的第一个接口,根据实际情况可能需要选择特定的接口 /* config MQTT context param */ { client.uri = MQTT_TEST_SERVER_URI; /* config connect param */ memcpy(&client.condata, &condata, sizeof(condata)); if (netif != RT_NULL) { client.condata.clientID.cstring = ipaddr_ntoa(&(netif->ip_addr)); } else { client.condata.clientID.cstring = MQTT_CLIENTID; } rt_kprintf("ClientID=%s\n", client.condata.clientID.cstring); client.condata.keepAliveInterval = 60; client.condata.cleansession = 1; client.condata.username.cstring = MQTT_USERNAME; client.condata.password.cstring = MQTT_PASSWORD; /* config MQTT will param. */ client.condata.willFlag = 1; client.condata.will.qos = MQTT_TEST_QOS; client.condata.will.retained = 0; strcpy(buffer, MQTT_PUB_ORDER); // 将第一个字符串复制到缓冲区 strcat(buffer, MQTT_DEVICE_ID); // 将第二个字符串追加到缓冲区 strcat(buffer, MQTT_PUBTOPIC); // 将第二个字符串追加到缓冲区 client.condata.will.topicName.cstring = buffer; rt_kprintf("Publish=%s\n", client.condata.will.topicName.cstring); client.condata.will.message.cstring = MQTT_WILLMSG; /* malloc buffer. */ client.buf_size = client.readbuf_size = MQTT_PUB_SUB_BUF_SIZE; client.buf = rt_malloc(client.buf_size); client.readbuf = rt_malloc(client.readbuf_size); if (!(client.buf && client.readbuf)) { rt_kprintf("no memory for MQTT client buffer!\n"); goto _exit; } /* set event callback function */ client.connect_callback = mqtt_connect_callback; client.online_callback = mqtt_online_callback; client.offline_callback = mqtt_offline_callback; /* set subscribe table and event callback */ client.messageHandlers[0].topicFilter = rt_strdup(MQTT_SUBTOPIC); client.messageHandlers[0].callback = mqtt_sub_callback; client.messageHandlers[0].qos = MQTT_TEST_QOS; /* set default subscribe event callback */ client.defaultMessageHandler = mqtt_sub_callback; } /* run mqtt client */ paho_mqtt_start(&client); return; _exit: if (client.buf) { rt_free(client.buf); client.buf = RT_NULL; } if (client.readbuf) { rt_free(client.readbuf); client.readbuf = RT_NULL; } return; } ``` mqtt的publish线程 ```c void thread_pub(void *parameter) { data_packet_t packet; rt_kprintf("thread_pub start\n"); while (1) { if (rt_mq_recv(tx7_mq, &packet, sizeof(data_packet_t), RT_WAITING_FOREVER) == RT_EOK) { rt_kprintf("rt_mq_recv(tx7_mq)\n"); switch (packet.mode) { case READ_INFO_BACK: { // 创建根对象 cJSON *root = cJSON_CreateObject(); // 添加 DeviceID cJSON_AddItemToObject(root, "DeviceID", cJSON_CreateNumber(1)); // 添加 ArgCount cJSON_AddItemToObject(root, "ArgCount", cJSON_CreateNumber(30)); // 添加 Result cJSON_AddItemToObject(root, "Result", cJSON_CreateString("Success")); cJSON_AddItemToObject(root, "Message", cJSON_CreateString("ok")); // 创建 DeviceInfo 对象 cJSON *deviceInfo = cJSON_CreateObject(); cJSON_AddItemToObject(root, "DeviceInfo", deviceInfo); // 向 DeviceInfo 添加字段 cJSON_AddItemToObject(deviceInfo, "UserID", cJSON_CreateNumber(0)); cJSON_AddItemToObject(deviceInfo, "PowerCurveEnable", cJSON_CreateString("true")); cJSON_AddItemToObject(deviceInfo, "CountFunctionEnable", cJSON_CreateString("false")); cJSON_AddItemToObject(deviceInfo, "RepeatResultEnable", cJSON_CreateString("true")); cJSON_AddItemToObject(deviceInfo, "MonitorModeEnable", cJSON_CreateString("true")); cJSON_AddItemToObject(deviceInfo, "BusType", cJSON_CreateString("true")); cJSON_AddItemToObject(deviceInfo, "Spots4Bytes", cJSON_CreateString("false")); cJSON_AddItemToObject(deviceInfo, "DeviceID", cJSON_CreateNumber(1)); cJSON_AddItemToObject(deviceInfo, "SampleSource", cJSON_CreateString("true")); cJSON_AddItemToObject(deviceInfo, "ControllerBoxType", cJSON_CreateNumber(70400)); cJSON_AddItemToObject(deviceInfo, "DisplayRate", cJSON_CreateNumber(1000)); cJSON_AddItemToObject(deviceInfo, "SamplingRate", cJSON_CreateNumber(1000)); cJSON_AddItemToObject(deviceInfo, "MainBoardType", cJSON_CreateNumber(0)); cJSON_AddItemToObject(deviceInfo, "MainBoardSoftVersion", cJSON_CreateString("1.01")); cJSON_AddItemToObject(deviceInfo, "DutyCollectEnable", cJSON_CreateString("false")); // cJSON_AddItemToObject(deviceInfo, "IOMonitorEnable", cJSON_CreateString("false")); char *updated_json_str = cJSON_Print(root); if (!updated_json_str) { rt_kprintf("Failed to print JSON\n"); cJSON_Delete(root); return; } if (client.isconnected) { rt_kprintf("mqtt_publish %d:%s:\n", pub_count, buffer); print_long_string(updated_json_str); // rt_kprintf("%s\n", updated_json_str); if (!paho_mqtt_publish(&client, QOS1, buffer, updated_json_str)) { ++pub_count; } } else { rt_kprintf("client.is not connected\n"); } if (updated_json_str) { rt_free(updated_json_str); updated_json_str = RT_NULL; } cJSON_Delete(root); } break; default: break; } } } } ```
查看更多
1
个回答
默认排序
按发布时间排序
heke
2024-07-09
这家伙很懒,什么也没写!
   增加堆栈后依然不行,并且下图增加Log后显示执行了两次,而且toplic是错的,第2次时payload的长度特别大 
撰写答案
登录
注册新账号
关注者
0
被浏览
428
关于作者
heke
这家伙很懒,什么也没写!
提问
13
回答
8
被采纳
0
关注TA
发私信
相关问题
1
umqtt 软件包使用后,连接上emqx服务器,过一会儿就掉线了
2
使用正点原子的 潘多拉 开发板 的例程19_iot_mqtt
3
mqtt软件包,不支持直接关闭?
4
kawaii_mqtt 申请内存崩溃
5
_signal_entry() 函数中dbg_enter在哪里定义呢?
6
start to connect mqtt server 失败
7
MQTT 在“ read 0:1, break “后断开重连
8
paho_mqtt线程相关疑问
9
RT thread studio kawaii mqtt 无法连接EMQ
10
调试bc26 ,断言错误failed at rt_thread_timeout
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
2
RT-Thread中的time溢出问题,时间戳溢出,解决方法
3
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
4
SystemView线程名字不显示
5
只用网页也能跑RT-Smart 无门槛腾讯Cloud studio + smart-build快速构建
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
UART
ESP8266
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
9
个答案
2
次被采纳
三世执戟
8
个答案
1
次被采纳
KunYi
8
个答案
1
次被采纳
xiaorui
3
个答案
1
次被采纳
winfeng
2
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
4
次点赞
Days
1
篇文章
4
次点赞
YZRD
1
篇文章
2
次点赞
阳光的掌控者
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部