目錄
編程思路簡介
服務器一次推送的消息可能不止一條,可能是多條消息打包推送的,所以在解讀每條消息之前,我們先要解包,把消息逐條提取存放
接受的數據 = n個消息組成
消息的長度 = 剩餘長度 + 剩餘長度所佔字節 + 1
代碼實現
typedef struct
{
u8 message_Cnt; //消息的條數
u16 message_Leng[message_RecMax];
u8 message[message_RecMax][message_RecLeng]; //消息緩衝區
}publish_RecDataStruct;
之所以這樣定義結構體,爲了方便數據的讀取
void publish_RecPackAnalys(u8 *rec_Data)
{
u8 i;
u32 rec_DataLeng; //接受字節總長
u32 remind_Leng = 0; //剩餘長度
u8 remind_LengLocal = 1; //剩餘長度 在單個消息中所在當前位置
u8 remind_LengByteCnt = 0; //剩餘字節所佔位數
u16 message_Loacl;
u8 *rec_DataBkp = rec_Data;
// rec_DataLeng = 15; //測試使用
rec_DataLeng = mqtt_RxSta & 0X7F; //得到接受數據的總長度
do
{
publish_RecData.message_Cnt++; //統計消息的個數
do
{
if(remind_LengByteCnt++)
{
remind_Leng += (rec_Data[remind_LengLocal] & 0X7F) * 128;
}
else
{
remind_Leng += rec_Data[remind_LengLocal] & 0X7F;
}
}while(rec_Data[remind_LengLocal++] >> 7); //爲 1 時執行循環,說明此時剩餘字節第一位 爲 1
publish_RecData.message_Leng[publish_RecData.message_Cnt - 1] = 1 + remind_LengByteCnt + remind_Leng; //計算當前消息長度
rec_DataLeng -= publish_RecData.message_Leng[publish_RecData.message_Cnt - 1]; //接受數據長度減去當前消息長度
rec_Data = &rec_Data[publish_RecData.message_Leng[publish_RecData.message_Cnt - 1]]; //rec_Data指向下一個消息的開頭
/*********************************** 爲下一次循環做準備 ****************************************/
remind_LengByteCnt = 0;
remind_Leng = 0;
remind_LengLocal = 1;
}while(rec_DataLeng); //此段循環代碼解析出了 消息數量,每個消息的長度
rec_Data = rec_DataBkp;
for(i = 0; i<publish_RecData.message_Cnt; i++)
{
memcpy(*(publish_RecData.message + i),&rec_Data[message_Loacl],publish_RecData.message_Leng[i]);
*(*(publish_RecData.message + i)+publish_RecData.message_Leng[i]) = '\0';
message_Loacl += publish_RecData.message_Leng[i];
}
}