MQTT協議C語言實現-接收服務器推送消息處理

編程思路簡介

服務器一次推送的消息可能不止一條,可能是多條消息打包推送的,所以在解讀每條消息之前,我們先要解包,把消息逐條提取存放

接受的數據 = 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];
	}	
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章