C語(yǔ)言實(shí)現(xiàn)AT指令A(yù)SCII碼的拼接處理流程
在GSM模塊、NBIOT模塊、4G模塊的C/C++編程當(dāng)中,很多這樣的模塊已經(jīng)做成了標(biāo)準(zhǔn)的AT指令集,難免涉及到字符串的操作,比如拆分,拼接成一個(gè)AT指令。
眾所周知,AT指令我感覺(jué)太惡心,為啥要設(shè)計(jì)出格式如此復(fù)雜的指令發(fā)送和回復(fù)?不過(guò)既然有標(biāo)準(zhǔn),那肯定也有應(yīng)對(duì)方法。
最近在使用NBIOT---BC28模塊,我的任務(wù)是將IMEI碼與IMSI碼讀出來(lái)后,利用AT指令將其拼接起來(lái)后發(fā)到easyiot平臺(tái),如圖所示:

最終我要在下位機(jī)上實(shí)現(xiàn)發(fā)送該命令將數(shù)據(jù)上報(bào)。
AT+QLWULDATAEX=57,01F00035000150FFFFFFCE3436303131313137343535363734353836373732363033303036393336350000016651A049580100040200013191,0x0100 //設(shè)備消息上報(bào)
程序源碼實(shí)現(xiàn):
首先需要將IMEI和IMSI碼的字符串中的字符全部轉(zhuǎn)換為ASCII碼,我們用到這個(gè)函數(shù):
//將字符串(只包含數(shù)字)全部轉(zhuǎn)換成ascii
int strnumber_to_asciistr(char *dest,const char *src,int len)
{
int i = 0 ;
if(0 == len || NULL == src || NULL == dest)
return -1;
else
{
for(i = 0 ; i < len ; i++,src++)
{
if(*src < '0' || *src > '9')
return -2 ;
*dest++ = "0123456789"[*src >> 4];
*dest++ = "0123456789"[*src & 0x0f];
}
*dest = '\0';
return 0 ;
}
}
該函數(shù)源碼由我們?nèi)旱囊粋€(gè)資深軟件工程師提供,再經(jīng)過(guò)參考和修改而成,主要的作用如我所說(shuō):

比如傳入一個(gè)src字符串為:0123456789,那么相應(yīng)的dest為30313233343536373839,前提是dest有足夠的內(nèi)存空間。
接下來(lái)實(shí)現(xiàn)源碼,傳入任意的IMSI碼與IMEI碼,瞬間轉(zhuǎn)化成可以發(fā)送的AT指令:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//將字符串(只包含數(shù)字)全部轉(zhuǎn)換成ascii
int strnumber_to_asciistr(char *dest,const char *src,int len)
{
int i = 0 ;
if(0 == len || NULL == src || NULL == dest)
return -1;
else
{
for(i = 0 ; i < len ; i++,src++)
{
if(*src < '0' || *src > '9')
return -2 ;
*dest++ = "0123456789"[*src >> 4];
*dest++ = "0123456789"[*src & 0x0f];
}
*dest = '\0';
return 0 ;
}
}
void Send_Data_To_easyiot(char *__imsi,char *__imei,int property ,int status)
{
char nb_code_buf[30] = {0};
char nb_code_buf1[30] = {0};
char cmd_buf[200] = {0};
u8 serial = 0 ;
u8 status_bit = 0 ;
//IMSI整體轉(zhuǎn)ASCII
strnumber_to_asciistr(nb_code_buf,imei,15);
//IMEI整體轉(zhuǎn)ASCII
strnumber_to_asciistr(nb_code_buf1,imsi,15);
if(property == 1)
serial = 2 ;
else
serial = 1 ;
if(status == 0)
status_bit = 0x3A;
else
status_bit = 0x3B;
sprintf(cmd_buf,"AT+QLWULDATAEX=57,01F00035000150FFFFFFCE%s%s000001667A5DF5700%d00040%d0001%d%x,0x0100",nb_code_buf,nb_code_buf1,serial,status,status+30,status_bit);
printf("拼接AT指令::%s\n",cmd_buf);
}
int main(void)
{
int i ;
char *_imei = "460111174556744";
char *_imsi = "867726030069368";
char imei[31];
char imsi[31];
char cmd_buf[150];
char value = 0 ;
int property = 0;
int status = 1 ;
printf("原來(lái)的imei:%s\n",_imei);
printf("原來(lái)的imsi:%s\n",_imsi);
Send_Data_To_easyiot(_imsi,_imei,1,1);
return 0;
}
運(yùn)行結(jié)果:

總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
C++11學(xué)習(xí)之右值引用和移動(dòng)語(yǔ)義詳解
c++11中引用了右值引用和移動(dòng)語(yǔ)義,可以避免無(wú)謂的復(fù)制,提高了程序性能。這篇文章將通過(guò)一些示例和大家聊聊右值引用和移動(dòng)語(yǔ)義的使用,感興趣的可以了解一下2023-02-02
C++實(shí)現(xiàn)含附件的郵件發(fā)送功能
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)含附件的郵件發(fā)送功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
QT實(shí)現(xiàn)用戶(hù)登錄注冊(cè)功能
這篇文章主要為大家詳細(xì)介紹了QT實(shí)現(xiàn)用戶(hù)登錄注冊(cè)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
舉例理解C語(yǔ)言二維數(shù)組的指針指向問(wèn)題
這篇文章主要介紹了C語(yǔ)言二維數(shù)組的指針指向問(wèn)題,文中不建議用二級(jí)指針來(lái)訪問(wèn)二維數(shù)組,需要的朋友可以參考下2015-12-12
C++如何解決rand()函數(shù)生成的隨機(jī)數(shù)每次都一樣的問(wèn)題
這篇文章主要介紹了C++如何解決rand()函數(shù)生成的隨機(jī)數(shù)每次都一樣的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
基于OpenCv的運(yùn)動(dòng)物體檢測(cè)算法
這篇文章主要為大家詳細(xì)介紹了基于OpenCv的運(yùn)動(dòng)物體檢測(cè)算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01

