tt808.c 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995
  1. #include "tt808.h"
  2. #include "usart.h"
  3. #include "key.h"
  4. #include <stdio.h>
  5. #include <time.h>
  6. #include <stdlib.h>
  7. #include <string.h>
  8. #include "rtc.h"
  9. #include "database.h"
  10. //*整型
  11. int rlt;
  12. uint16_t uploadtime=0; //上传时间
  13. uint16_t hccd = 0;//ascii个数(*2)
  14. uint8_t header[12]; //处理头部
  15. uint8_t index_2c = 0;
  16. uint8_t MIPurc[100]; //接收平台数据
  17. uint8_t MIPurc1[100]; //接收平台数据
  18. uint8_t MIPurcXXTCSJ[100];//平台下行透传数据
  19. uint8_t speedBegin=0;
  20. uint8_t speedEnd=0;
  21. uint8_t speed[10]; //处理头部
  22. uint8_t DTUurc[100]; //接收平台数据
  23. uint8_t DTUurc1[15]; //接收平台数据
  24. int pushpullcount = 0;
  25. double dSpeed=0;
  26. double dlatitude=0;
  27. double dlongitude=0;
  28. char cSpeed[10];
  29. char clatitude[15];
  30. char clongitude[15];
  31. char csatellitesNum[5];
  32. char MGNSSLOC[100]; //接收定位数据
  33. char CSQ[12]; //接收定位数据
  34. char MGNSSLOC_time[6]; //接收定位数据
  35. uint32_t Stamp =0;
  36. uint8_t GNSSdata[40]={0};
  37. //*结构体
  38. TT808 tt808;
  39. extern TipsFlag tipsflag;
  40. extern Menu_table menu;
  41. extern bool refresh;
  42. extern LockInfo lockinfo;
  43. //*布尔
  44. bool authFlag = false;
  45. bool GnssFlag = false;
  46. bool Offline = false;
  47. bool Retrans = false;
  48. bool Online = false;
  49. bool reIME = false;
  50. bool reAuth = false;//回复权限
  51. /**
  52. 时间 纬度(北纬) 经度(东经) 水平精度因子 海拔高度 定位类型(1无,2 2d,3 3d) 运动角度 水平运动速度(KM/h) 水平运动速度(Knots) 日月年 卫星数量 差分定位标识(1单点,2差分)
  53. eg.+MGNSSLOC: 015032.301,3014.8605N,12001.9250E,1.8, 17.6, 3, 0.00, 3.6, 1.9, 080424, 12, 1
  54. */
  55. void reconn(void)
  56. {
  57. char TCPconnvalue[120];
  58. TcpConn(TCPconnvalue, 1, JLPTIP, JLPTPORT,0); //cid=1 tcpConnmode=0 普通模式
  59. if(sendCmd_4G(TCPconnvalue, "+MIPOPEN: 1,0", 1, 1)) //TCP连接 0普通模式 2缓存模式 1透传模式
  60. {
  61. printf("重连成功\r\n");
  62. }
  63. }
  64. uint8_t Messagetemp_length=0;
  65. uint8_t MessageHandleData[100]; //放入封装后数据
  66. uint8_t tcppacket[100]; //消息数据
  67. void MessageHandle(uint16_t MessageID)
  68. {
  69. Flash_ReadBytes((uint16_t*)&(tt808.LSH),tt808serialNum,1);//读取loc头部是否发生写入
  70. if(tt808.LSH==0xFFFF)
  71. {
  72. tt808.LSH=0;//初始未写入
  73. }
  74. uint16_t MessageAttributeData = Messagetemp_length;
  75. MessageAttributeData |= ( Messagetemp_length | (TCPJMFSNULL<<10)); // 将长度左移3位后和加密方式进行按位或操作(001 RSA ,000 无加密)
  76. header[0] = ((MessageID>>8)&0xff);
  77. header[1] = (MessageID&0xff); //消息ID
  78. header[2] = ((MessageAttributeData>>8)&0xff);
  79. header[3] = (MessageAttributeData&0xff); //消息属性
  80. //*test phoneNumxy
  81. //*work phoneNum
  82. if(phonenull)
  83. {
  84. header[4] = 0x00;
  85. header[5] = 0x00;
  86. header[6] = 0x16;
  87. header[7] = 0x00;
  88. header[8] = 0x00;
  89. header[9] = 0x08; //“手机号”
  90. }
  91. else
  92. {
  93. header[4] = (phonenum[0]>>8)&0xff;
  94. header[5] = (phonenum[0])&0xff;
  95. header[6] = (phonenum[1]>>8)&0xff;
  96. header[7] = (phonenum[1])&0xff;
  97. header[8] = (phonenum[2]>>8)&0xff;
  98. header[9] = (phonenum[2])&0xff; //“手机号”
  99. }
  100. header[10] = ((tt808.LSH>>8)&0xff);
  101. header[11] = (tt808.LSH&0xff);
  102. int index = 0;
  103. tcppacket[index++] = TT808FLAG; // Set the headflag 0x7E
  104. for (int i = 0; i < 12; i++) {
  105. tcppacket[index++] = header[i];
  106. }
  107. // Copy message body to packet
  108. for (size_t i = 0; i < Messagetemp_length; i++) {
  109. tcppacket[index++] = MessageHandleData[i];
  110. }
  111. tcppacket[index++] = xorBytes(&tcppacket[1],12+Messagetemp_length);; // Set the checksum
  112. tcppacket[index++] = TT808FLAG; // Set the flag at the end
  113. for (int i = 0; i < index; i++) {
  114. printf("%02X ", tcppacket[i]); // 以十六进制格式打印每个元素
  115. }
  116. printf("\r\n");
  117. //#if open4G ==1
  118. char TCPvalue[120];
  119. char *ptr = TCPvalue;
  120. ptr += sprintf(ptr, "AT+MIPSEND=1,%d,\"",index);
  121. for (int i = 0; i < index; i++) {
  122. ptr += sprintf(ptr, "%02X", tcppacket[i]);
  123. }
  124. sprintf(ptr, "\"\r\n");//TCPvalue
  125. if(sendCmd_4G(TCPvalue, "+MIPSEND:", 1, 1))//发送
  126. {
  127. printf("#等待回应\r\n");
  128. }
  129. //#endif
  130. tt808.LSH+=1;//需做写入处理
  131. Flash_WriteBytes((uint16_t*)&(tt808.LSH),tt808serialNum,1);
  132. }
  133. uint16_t swapBytes16(uint16_t value) {
  134. return (value >> 8) | (value << 8);
  135. }
  136. uint32_t swapBytes32(uint32_t value) {
  137. return ((value & 0xFF) << 24) | ((value & 0xFF00) << 8) |
  138. ((value >> 8) & 0xFF00) | ((value >> 24) & 0xFF);
  139. }
  140. /**
  141. * @breaf 消息体封装
  142. * Message[] 消息数据; length 消息数据长度; outMessage[] 封装后消息数据; MessageID 消息ID
  143. */
  144. uint8_t Message_bodydata(uint8_t *Message, uint8_t length, uint8_t outMessage[],uint16_t MessageID)
  145. {
  146. int index = 0;
  147. uint8_t temp_length = 0;//加首尾 25/23/crc
  148. if(MessageID==MessageID_authentication || MessageID==MessageID_heartbeat || MessageID==MessageID_Getauth)//不加头尾(鉴权、心跳、获取权限)
  149. {
  150. temp_length = length;//不加首尾
  151. uint8_t temp_Message[temp_length];
  152. for (int i = 0; i < length; i++) {
  153. temp_Message[index++] = Message[i]; // 将消息头拷贝到报文中
  154. }
  155. temp_length = index;
  156. for(int i =0;i<temp_length;i++)
  157. {
  158. outMessage[i]=temp_Message[i];
  159. }
  160. }
  161. else if(MessageID==MessageID_location)//终端地址0200 补传0704
  162. {
  163. temp_length = length;//不加首尾
  164. //状态标志/纬度/经度/速度
  165. uint8_t temp_Message[temp_length];
  166. for (int i = 0; i < length; i++) {
  167. temp_Message[index++] = Message[i]; // 将消息头拷贝到报文中
  168. }
  169. for(int i =0;i<temp_length;i++)
  170. {
  171. outMessage[i]=temp_Message[i];
  172. }
  173. }
  174. else if(MessageID==MessageID_Retrans)// 补传0704+5
  175. {
  176. temp_length = length;//不加首尾
  177. uint8_t temp_Message[temp_length];
  178. temp_Message[index++] = 0x00;
  179. temp_Message[index++] = 0x01;
  180. temp_Message[index++] = 0x00;
  181. temp_Message[index++] = 0x00;
  182. temp_Message[index++] = 0x22;
  183. for (int i = 0; i < length; i++) {
  184. temp_Message[index++] = Message[i]; // 将消息头拷贝到报文中
  185. }
  186. for(int i =0;i<temp_length;i++)
  187. {
  188. outMessage[i]=temp_Message[i];
  189. }
  190. }
  191. else//加首尾
  192. {
  193. temp_length = length+3;//加首尾 25/23/crc
  194. uint8_t temp_Message[temp_length];
  195. temp_Message[index++]=temp_length;
  196. temp_Message[index++]=0x2A;
  197. for (int i = 0; i < length; i++) {
  198. temp_Message[index++] = Message[i]; // 将消息头拷贝到报文中
  199. }
  200. temp_Message[index++]=0x23;
  201. temp_Message[index++]=xorBytes(&temp_Message[1],temp_length-1);
  202. temp_length = index;
  203. for(int i =0;i<temp_length;i++)
  204. {
  205. outMessage[i]=temp_Message[i];
  206. }
  207. }
  208. return temp_length;
  209. }
  210. /*需要传入消息体长度sizeof(Message)/sizeof(Message[0]);*/
  211. void tt808FsFunc(uint8_t* Message, uint8_t length, uint16_t MessageID)
  212. {
  213. HAL_Delay(200);
  214. Messagetemp_length = Message_bodydata(Message, length, MessageHandleData, MessageID);
  215. MessageHandle(MessageID);
  216. }
  217. void printBytes(uint8_t *data, size_t length) {
  218. for (size_t i = 0; i < length; i++) {
  219. printf("%02x ", data[i]);
  220. }
  221. printf("\n");
  222. }
  223. // 函数用于提取第7到第8个逗号之间的字符串
  224. void extractString(char* receiveStr, char* result, uint8_t start, uint16_t end)
  225. {
  226. int comma_count = 0;
  227. int start_index = -1;
  228. int end_index = -1;
  229. int length = strlen(receiveStr);
  230. // 遍历字符串,统计逗号数量和记录起始和结束索引
  231. for (int i = 0; i < length; i++)
  232. {
  233. if (receiveStr[i] == ',')
  234. {
  235. comma_count++;
  236. if (comma_count == start)
  237. {
  238. start_index = i + 1; // 第start个逗号之后的字符
  239. }
  240. else if (comma_count == end)
  241. {
  242. if(start==1 && end==2)//*纬度去尾符号
  243. {
  244. end_index = i-1; // 第end个逗号之前的字符
  245. }
  246. else if(start==2 && end==3)//*经度去尾符号
  247. {
  248. end_index = i-1; // 第end个逗号之前的字符
  249. }
  250. else
  251. {
  252. end_index = i; // 第end个逗号之前的字符
  253. }
  254. break;
  255. }
  256. }
  257. }
  258. // 提取字符串并存储在result数组中
  259. if (start_index != -1 && end_index != -1 && start_index < end_index)
  260. {
  261. strncpy(result, receiveStr + start_index, end_index - start_index);
  262. result[end_index - start_index] = '\0'; // 添加字符串结束符
  263. }
  264. }
  265. void extractStringPoint(char* receiveStr, char* result, uint8_t start, uint16_t end)
  266. {
  267. int comma_count = 0;
  268. int start_index = -1;
  269. int end_index = -1;
  270. int length = strlen(receiveStr);
  271. // 遍历字符串,统计逗号数量和记录起始和结束索引
  272. for (int i = 0; i < length; i++)
  273. {
  274. if(start==0 && end==1)// = -> .
  275. {
  276. start_index = start; // 第start个逗号之后的字符
  277. if (receiveStr[i] == '.')
  278. {
  279. comma_count++;
  280. }
  281. else if (comma_count == end)
  282. {
  283. end_index = i-1; // 第end个逗号之前的字符
  284. break;
  285. }
  286. }
  287. else if(start==3 && end==4)
  288. {
  289. if (receiveStr[i] == '.')
  290. {
  291. comma_count++;
  292. if (comma_count == start)
  293. {
  294. start_index = i + 1; // 第start个逗号之后的字符
  295. }
  296. }
  297. else if(receiveStr[i] == ':')
  298. {
  299. end_index = i;
  300. }
  301. }
  302. else if(start==4 && end==5)
  303. {
  304. if (receiveStr[i] == ':')
  305. {
  306. comma_count=4;
  307. if (comma_count == start)
  308. {
  309. start_index = i+1; // 第start个逗号之后的字符
  310. }
  311. end_index = start_index+4;
  312. break;
  313. }
  314. }
  315. else
  316. {
  317. if (receiveStr[i] == '.')
  318. {
  319. comma_count++;
  320. if (comma_count == start)
  321. {
  322. start_index = i + 1; // 第start个逗号之后的字符
  323. }
  324. else if (comma_count == end)
  325. {
  326. end_index = i; // 第end个逗号之前的字符
  327. break;
  328. }
  329. }
  330. }
  331. }
  332. // 提取字符串并存储在result数组中
  333. if (start_index != -1 && end_index != -1 && start_index < end_index)
  334. {
  335. strncpy(result, receiveStr + start_index, end_index - start_index);
  336. result[end_index - start_index] = '\0'; // 添加字符串结束符
  337. }
  338. }
  339. double convertToDouble(char* str) {
  340. if(str == csatellitesNum)
  341. {
  342. uint8_t result;
  343. sscanf(str, "%hhu", &result);
  344. return result;
  345. }
  346. else
  347. {
  348. double result;
  349. sscanf(str, "%lf", &result);
  350. return result;
  351. }
  352. }
  353. char hex2asc(const char *hex)
  354. {
  355. char asc = 0;
  356. char a = (hex[0]>='A' && hex[0]<='F')?(hex[0]^32):hex[0];
  357. char b = (hex[1]>='A' && hex[1]<='F')?(hex[1]^32):hex[1];
  358. if ((a>='0' && a<='9' || a>='a' && a<='f') && (b>='0' && b<='9' || b>='a' && b<='f')){
  359. asc = ((('a'<=a && a<='f')?(a-'a')+10:a-'0')<<4)|(('a'<=b && b<='f')?(b-'a')+10:b-'0');
  360. }
  361. return asc;
  362. }
  363. uint8_t testHex2Asc(const char *hex) {
  364. char asc = hex2asc(hex);
  365. printf("Hex: %s\tASC: %d\n", hex, asc);
  366. return asc;
  367. }
  368. char *bin2hex(char *hex, const unsigned char *bin, int size)
  369. {
  370. size_t i;
  371. for(i=0; i<size; i++)
  372. {
  373. sprintf(hex+i*2, "%02x", bin[i]);
  374. }
  375. hex[i+i] = 0;
  376. return hex;
  377. }
  378. int hex2bin(unsigned char *bin, const char *hex)
  379. {
  380. const char *h = hex;
  381. unsigned char *b = bin;
  382. int rlt = 0;
  383. while(*h){
  384. *b++ = hex2asc(h);
  385. h = h + 2;
  386. rlt++;
  387. }
  388. return rlt;//长度
  389. }
  390. // 将单个十六进制数转换为 BCD 码
  391. uint8_t hexToBcd(uint8_t hex) {
  392. return ((hex / 10) << 4) | (hex % 10);
  393. }
  394. // 将整数数组中的所有十六进制数转换为 BCD 码
  395. void hexArrayToBcd(uint8_t* array, size_t length, uint8_t* out) {//时间用
  396. array[3]+=8;
  397. for (size_t i = 0; i < length; i++) {
  398. out[i] = hexToBcd(array[i]);
  399. }
  400. }
  401. void hexToBcd_arr(uint8_t* array, size_t length, uint8_t* out) {//通用
  402. for (size_t i = 0; i < length; i++) {
  403. out[i] = hexToBcd(array[i]);
  404. }
  405. }
  406. char input_strings[20]={0};
  407. char reIp0[10];
  408. char reIp1[10];
  409. char reIp2[10];
  410. char reIp3[10];
  411. char reIpP[10];
  412. Ipaddr ipaddr;
  413. MacSet macset;
  414. MacSet *macsetptr = &macset;
  415. char Newip[30];
  416. extern bool wdiFlag;
  417. //*485测试命令
  418. void Test485Re(void)
  419. {
  420. //*test485 模拟
  421. if(strncmp((char*)U1_485recvBuff, "+MIPURC: \"disconn\",1,1", strlen("+MIPURC: \"disconn\",1,1"))==0)//"disconn" 平台断连
  422. {
  423. Offline=true;
  424. uploaweork=false;
  425. printf("@U1与平台断开连接\r\n");
  426. memset(U1_485recvBuff,0,BUFFER_SIZE);
  427. }
  428. else if(strncmp((char*)U1_485recvBuff, "+MIPOPEN: 1,0", strlen("+MIPOPEN: 1,0"))==0)//连接平台
  429. {
  430. Offline=false;
  431. Online = true;
  432. uploaweork=true;
  433. printf("@U1设备已上线!!\r\n");
  434. refresh=true;
  435. memset(U1_485recvBuff,0,BUFFER_SIZE);
  436. }
  437. else if(strncmp((char*)&U1_485recvBuff, "DTU+FLASH=deleteloc", strlen("DTU+FLASH=deleteloc"))==0)//连接平台
  438. {
  439. dblocptr->headinfo.loc_pushIndex=0;
  440. dblocptr->headinfo.loc_pullIndex=0;
  441. Flash_WriteBytes((uint16_t*)&(dblocptr->headinfo),LocDbHeadStart,4);//更新刻度
  442. memset(U1_485recvBuff,0,BUFFER_SIZE);
  443. printf("更新刻度成功\r\n");
  444. }
  445. else if(strncmp((char*)U1_485recvBuff, "DTU+JT808_IMEI=", strlen("DTU+JT808_IMEI="))==0)//修改IME号
  446. {
  447. memcpy(DTUurc1,U1_485recvBuff+15,12);
  448. const char *hex = (const char *)DTUurc1; // 将 uint8_t * 转换为 const char *
  449. int size = strlen(hex) / 2; // 计算二进制数据的长度
  450. unsigned char *bin = (unsigned char *)malloc(size); // 分配足够的内存用于存储二进制数据
  451. rlt = hex2bin(bin, hex); // 调用hex2bin函数进行转换
  452. memcpy(DTUurc, bin, rlt); // 将 bin 中的 rlt 个字节复制到 MIPurc1 中 接收到的数据放入MIPurc1中
  453. free(bin); // 释放内存
  454. //memset(DTUurc1,0,100);
  455. memset(U1_485recvBuff,0,BUFFER_SIZE);
  456. reIME = true;
  457. HAL_Delay(500);
  458. }
  459. else if(strncmp((char*)U1_485recvBuff, "DTU+JT808_SERVER=", strlen("DTU+JT808_SERVER="))==0)
  460. {
  461. memcpy(input_strings,U1_485recvBuff+17,20);
  462. extractStringPoint(input_strings,reIp0,0,1);
  463. extractStringPoint(input_strings,reIp1,1,2);
  464. extractStringPoint(input_strings,reIp2,2,3);
  465. extractStringPoint(input_strings,reIp3,3,4);
  466. extractStringPoint(input_strings,reIpP,4,5);
  467. ipaddr.IP0 = atoi(reIp0);
  468. ipaddr.IP1 = atoi(reIp1);
  469. ipaddr.IP2 = atoi(reIp2);
  470. ipaddr.IP3 = atoi(reIp3);
  471. ipaddr.IPp = atoi(reIpP);
  472. //printf("%d.%d.%d.%d:%d",ipaddr.IP0,ipaddr.IP1,ipaddr.IP2,ipaddr.IP3,ipaddr.IPp);
  473. HAL_StatusTypeDef writeSta = Flash_WriteBytes((uint16_t*)&(ipaddr.IP0),ReIPAddr,5);
  474. if(writeSta == HAL_OK)
  475. {
  476. char *ptr = Newip;
  477. ptr += sprintf(ptr, "%d.", ipaddr.IP0);
  478. ptr += sprintf(ptr, "%d.", ipaddr.IP1);
  479. ptr += sprintf(ptr, "%d.", ipaddr.IP2);
  480. ptr += sprintf(ptr, "%d", ipaddr.IP3);
  481. printf("更换IP成功\r\n");
  482. }
  483. //ptr += sprintf(ptr, ":%d", ipaddr.IPp);
  484. //printf("%s\r\n",Newip);
  485. memset(U1_485recvBuff,0,BUFFER_SIZE);
  486. HAL_Delay(500);
  487. printf("即将重启\r\n");
  488. wdiFlag = true;
  489. }
  490. else if(strncmp((char*)U1_485recvBuff, "DTU+VER=?", strlen("DTU+VER=?"))==0)
  491. {
  492. printf("%s\r\n",version);
  493. memset(U1_485recvBuff,0,BUFFER_SIZE);
  494. }
  495. REPdaMode();//PDA 485 MQTT
  496. }
  497. void AtPRocess(char *value, char conn[],char connected[],char disconn[]) {
  498. // 使用snprintf代替sprintf以确保不会发生缓冲区溢出
  499. snprintf(conn, strlen(value) + 12, "AT+CONN=%s\r\n", value);
  500. snprintf(connected, strlen(value) + 14, "+CONNECTED:0,%s", value);
  501. snprintf(disconn, strlen(value) + 12, "+DISCONN:0,%s", value);
  502. printf("%s\r\n", conn);
  503. printf("%s\r\n", connected);
  504. printf("%s\r\n", disconn);
  505. }
  506. void Process_str_collections()
  507. {
  508. if(macset.macCount==1){
  509. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);}
  510. else if(macset.macCount==2){
  511. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);
  512. AtPRocess(lockinfo.SN2name,macset.SN2CONN, macset.SN2ED, macset.SN2DIS);}
  513. else if(macset.macCount==3){
  514. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);
  515. AtPRocess(lockinfo.SN2name,macset.SN2CONN, macset.SN2ED, macset.SN2DIS);
  516. AtPRocess(lockinfo.SN3name,macset.SN3CONN, macset.SN3ED, macset.SN3DIS);}
  517. else if(macset.macCount==4){
  518. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);
  519. AtPRocess(lockinfo.SN2name,macset.SN2CONN, macset.SN2ED, macset.SN2DIS);
  520. AtPRocess(lockinfo.SN3name,macset.SN3CONN, macset.SN3ED, macset.SN3DIS);
  521. AtPRocess(lockinfo.SN4name,macset.SN4CONN, macset.SN4ED, macset.SN4DIS);}
  522. else if(macset.macCount==5){
  523. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);
  524. AtPRocess(lockinfo.SN2name,macset.SN2CONN, macset.SN2ED, macset.SN2DIS);
  525. AtPRocess(lockinfo.SN3name,macset.SN3CONN, macset.SN3ED, macset.SN3DIS);
  526. AtPRocess(lockinfo.SN4name,macset.SN4CONN, macset.SN4ED, macset.SN4DIS);
  527. AtPRocess(lockinfo.SN5name,macset.SN5CONN, macset.SN5ED, macset.SN5DIS);}
  528. else if(macset.macCount==6){
  529. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);
  530. AtPRocess(lockinfo.SN2name,macset.SN2CONN, macset.SN2ED, macset.SN2DIS);
  531. AtPRocess(lockinfo.SN3name,macset.SN3CONN, macset.SN3ED, macset.SN3DIS);
  532. AtPRocess(lockinfo.SN4name,macset.SN4CONN, macset.SN4ED, macset.SN4DIS);
  533. AtPRocess(lockinfo.SN5name,macset.SN5CONN, macset.SN5ED, macset.SN5DIS);
  534. AtPRocess(lockinfo.SN6name,macset.SN6CONN, macset.SN6ED, macset.SN6DIS);}
  535. else if(macset.macCount==7){
  536. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);
  537. AtPRocess(lockinfo.SN2name,macset.SN2CONN, macset.SN2ED, macset.SN2DIS);
  538. AtPRocess(lockinfo.SN3name,macset.SN3CONN, macset.SN3ED, macset.SN3DIS);
  539. AtPRocess(lockinfo.SN4name,macset.SN4CONN, macset.SN4ED, macset.SN4DIS);
  540. AtPRocess(lockinfo.SN5name,macset.SN5CONN, macset.SN5ED, macset.SN5DIS);
  541. AtPRocess(lockinfo.SN6name,macset.SN6CONN, macset.SN6ED, macset.SN6DIS);
  542. AtPRocess(lockinfo.SN7name,macset.SN7CONN, macset.SN7ED, macset.SN7DIS);}
  543. else if(macset.macCount==8){
  544. AtPRocess(lockinfo.SN1name,macset.SN1CONN, macset.SN1ED, macset.SN1DIS);
  545. AtPRocess(lockinfo.SN2name,macset.SN2CONN, macset.SN2ED, macset.SN2DIS);
  546. AtPRocess(lockinfo.SN3name,macset.SN3CONN, macset.SN3ED, macset.SN3DIS);
  547. AtPRocess(lockinfo.SN4name,macset.SN4CONN, macset.SN4ED, macset.SN4DIS);
  548. AtPRocess(lockinfo.SN5name,macset.SN5CONN, macset.SN5ED, macset.SN5DIS);
  549. AtPRocess(lockinfo.SN6name,macset.SN6CONN, macset.SN6ED, macset.SN6DIS);
  550. AtPRocess(lockinfo.SN7name,macset.SN7CONN, macset.SN7ED, macset.SN7DIS);
  551. AtPRocess(lockinfo.SN8name,macset.SN8CONN, macset.SN8ED, macset.SN8DIS);}
  552. }
  553. void processPdadata(char MACtemp[], uint8_t mactemp[],uint16_t mac[])
  554. {
  555. const char *hex = (const char *)MACtemp; // 将 uint8_t * 转换为 const char *
  556. int size = strlen(hex) / 2; // 计算二进制数据的长度
  557. unsigned char *bin = (unsigned char *)malloc(size); // 分配足够的内存用于存储二进制数据
  558. rlt = hex2bin(bin, hex); // 调用hex2bin函数进行转换
  559. memcpy(mactemp, bin, rlt); // 将 bin 中的 rlt 个字节复制到 MIPurc1 中 接收到的数据放入MIPurc1中
  560. free(bin); // 释放内存
  561. mac[0] = mactemp[0]<<8|mactemp[1];
  562. mac[1] = mactemp[2]<<8|mactemp[3];
  563. mac[2] = mactemp[4]<<8|mactemp[5];
  564. }
  565. void REPdaMode(void)
  566. {
  567. HAL_StatusTypeDef WriteSta;
  568. //*PDA需求 485写入MAC号
  569. if(strncmp((char*)U1_485recvBuff, "DTU+ADDMAC", strlen("DTU+ADDMAC"))==0)
  570. {
  571. macset.macCount=0;
  572. memset(lockinfo.SN1name, 0, sizeof(lockinfo.SN1name));
  573. memset(lockinfo.SN2name, 0, sizeof(lockinfo.SN2name));
  574. memset(lockinfo.SN3name, 0, sizeof(lockinfo.SN3name));
  575. memset(lockinfo.SN4name, 0, sizeof(lockinfo.SN4name));
  576. memset(lockinfo.SN5name, 0, sizeof(lockinfo.SN5name));
  577. memset(lockinfo.SN6name, 0, sizeof(lockinfo.SN6name));
  578. memset(lockinfo.SN7name, 0, sizeof(lockinfo.SN7name));
  579. memset(lockinfo.SN8name, 0, sizeof(lockinfo.SN8name));
  580. erase_flash(MacDbBodyAddr);
  581. if(U1_485recvLength>12)
  582. {
  583. memcpy(macset.MACtemp1,U1_485recvBuff+11,12);
  584. processPdadata(macset.MACtemp1,macset.mactemp1,macset.mac1);
  585. WriteSta= Flash_WriteBytes(macsetptr->mac1,MacDbBodyAddr,3);
  586. if(WriteSta== HAL_OK) macset.macCount += 1;}
  587. if(U1_485recvLength>25){
  588. memcpy(macset.MACtemp2,U1_485recvBuff+24,12);
  589. processPdadata(macset.MACtemp2,macset.mactemp2,macset.mac2);
  590. WriteSta= Flash_WriteBytes(macsetptr->mac2,MacDbBodyAddr+(macset.macCount*6),3);
  591. if(WriteSta== HAL_OK) macset.macCount += 1;}
  592. if(U1_485recvLength>38){
  593. memcpy(macset.MACtemp3,U1_485recvBuff+37,12);
  594. processPdadata(macset.MACtemp3,macset.mactemp3,macset.mac3);
  595. WriteSta= Flash_WriteBytes(macsetptr->mac3,MacDbBodyAddr+(macset.macCount*6),3);
  596. if(WriteSta== HAL_OK) macset.macCount += 1;}
  597. if(U1_485recvLength>51){
  598. memcpy(macset.MACtemp4,U1_485recvBuff+50,12);
  599. processPdadata(macset.MACtemp4,macset.mactemp4,macset.mac4);
  600. WriteSta= Flash_WriteBytes(macsetptr->mac4,MacDbBodyAddr+(macset.macCount*6),3);
  601. if(WriteSta== HAL_OK) macset.macCount += 1;}
  602. if(U1_485recvLength>64){
  603. memcpy(macset.MACtemp5,U1_485recvBuff+63,12);
  604. processPdadata(macset.MACtemp5,macset.mactemp5,macset.mac5);
  605. WriteSta= Flash_WriteBytes(macsetptr->mac5,MacDbBodyAddr+(macset.macCount*6),3);
  606. if(WriteSta== HAL_OK) macset.macCount += 1;}
  607. if(U1_485recvLength>77){
  608. memcpy(macset.MACtemp6,U1_485recvBuff+76,12);
  609. processPdadata(macset.MACtemp6,macset.mactemp6,macset.mac6);
  610. WriteSta= Flash_WriteBytes(macsetptr->mac6,MacDbBodyAddr+(macset.macCount*6),3);
  611. if(WriteSta== HAL_OK) macset.macCount += 1;}
  612. if(U1_485recvLength>90){
  613. memcpy(macset.MACtemp7,U1_485recvBuff+89,12);
  614. processPdadata(macset.MACtemp7,macset.mactemp7,macset.mac7);
  615. WriteSta= Flash_WriteBytes(macsetptr->mac7,MacDbBodyAddr+(macset.macCount*6),3);
  616. if(WriteSta== HAL_OK) macset.macCount += 1;}
  617. if(U1_485recvLength>103){
  618. memcpy(macset.MACtemp8,U1_485recvBuff+102,12);
  619. processPdadata(macset.MACtemp8,macset.mactemp8,macset.mac8);
  620. WriteSta= Flash_WriteBytes(macsetptr->mac8,MacDbBodyAddr+(macset.macCount*6),3);
  621. if(WriteSta== HAL_OK) macset.macCount += 1;}
  622. if(WriteSta == HAL_OK)
  623. {
  624. printf("更新MAC存储完成共->%d\r\n",macset.macCount);
  625. }
  626. WriteSta = Flash_WriteBytes(&macsetptr->macCount,MacDbHeadAddr,1);
  627. if(WriteSta == HAL_OK)
  628. {
  629. printf("更新存储刻度完成\r\n");
  630. }
  631. ReadSNname();//更新
  632. Process_str_collections();//处理连接字符串
  633. memset(U1_485recvBuff,0,BUFFER_SIZE);
  634. }
  635. }
  636. void ReBTcall(void)
  637. {
  638. if(strncmp((char*)autoRe, "+CONNECTED:0,", strlen("+CONNECTED:0,"))==0)
  639. {
  640. memset(autoRe,0,BUFFER_SIZE);
  641. }
  642. }
  643. //*工作命令
  644. void ReMIPURC(void)//DTU
  645. {
  646. //*设备上线,发送成功
  647. if(strncmp((char*)U4_4GrecvBuff, "+MIPOPEN: 1,0", strlen("+MIPOPEN: 1,0"))==0)//连接平台
  648. {
  649. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  650. }
  651. ///*定位信息(MGNSS)
  652. else if(strncmp((char*)U4_4GrecvBuff, "+MGNSSURC: \"state\",1", strlen("+MGNSSURC: \"state\",1"))==0)
  653. {
  654. printf("@MGNSS设置成功\r\n");
  655. memset(U4_4GrecvBuff,0,strlen("+MGNSSURC: \"state\",1"));
  656. }
  657. else if(strncmp((char*)U4_4GrecvBuff, "+MGNSSURC: \"state\",0", strlen("+MGNSSURC: \"state\",0"))==0)//断开平台
  658. {
  659. printf("@主动取消GNSS\r\n");
  660. memset(U4_4GrecvBuff,0,strlen("+MGNSSURC: \"state\",0"));
  661. }
  662. ///*定位信息(基站)
  663. else if(((strncmp((char*)U4_4GrecvBuff, "+MGNSSLOC", strlen("+MGNSSLOC"))==0) || (strncmp((char*)U4_4GrecvBuff, "OK", strlen("OK"))==0)) && MgnssFlag) //监测平台回复+MGNSSLOC OK4f4b
  664. {
  665. memcpy(MGNSSLOC,&U4_4GrecvBuff[11],75);
  666. GnssFlag=true;
  667. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  668. }
  669. ///*掉线
  670. #if open4G ==1
  671. else if(strncmp((char*)U4_4GrecvBuff, "+MIPURC: \"disconn\",1,1", strlen("+MIPURC: \"disconn\",1,1"))==0)//"disconn" 平台断连
  672. {
  673. Offline=true;
  674. printf("@未发送成功,平台断开连接\r\n");
  675. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  676. uploaweork = false;
  677. reconn();//重连
  678. }
  679. else if((strncmp((char*)U4_4GrecvBuff, "+CPIN: SIM REMOVED", strlen("+CPIN: SIM REMOVED"))==0) || (strncmp((char*)U4_4GrecvBuff, "+CME ERROR: 10", strlen("+CME ERROR: 10"))==0) )//无SIM
  680. {
  681. //TODO
  682. printf("@SIM卡缺失\r\n");
  683. Offline=true;
  684. signal = false;
  685. menu.current = 0xBB;
  686. tipsflag = NoSIM;
  687. refresh=true;
  688. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  689. uploaweork = false;
  690. reconn();//重连
  691. }
  692. else if((strncmp((char*)U4_4GrecvBuff, "+MIPCALL: 1,0", strlen("+MIPCALL: 1,0"))==0))//意外断开平台连接!!!!//TCP未知错误
  693. {
  694. //TODO
  695. Offline=true;
  696. signal = false;
  697. printf("@与平台断开连接\r\n");
  698. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  699. uploaweork = false;
  700. reconn();//重连
  701. }
  702. else if( (strncmp((char*)U4_4GrecvBuff, "+CME ERROR: 550", strlen("+CME ERROR: 550"))==0))
  703. {
  704. Offline=true;
  705. signal = false;
  706. printf("@未发送成功->TCP/IP未知错误\r\n");
  707. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  708. uploaweork = false;
  709. reconn();//重连
  710. }
  711. else if((strncmp((char*)U4_4GrecvBuff, "+MIPOPEN: 1,571", strlen("+MIPOPEN: 1,571"))==0))//PDP激活失败
  712. {
  713. //TODO
  714. Offline=true;
  715. printf("@未发送成功,PDP激活失败\r\n");
  716. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  717. uploaweork = false;
  718. reconn();//重连
  719. }
  720. #endif
  721. else if(U4_4GrecvBuff[1]== 0x43 && U4_4GrecvBuff[2]== 0x53 && U4_4GrecvBuff[3]== 0x51)//CSQ 信号
  722. {
  723. memcpy(CSQ,U4_4GrecvBuff,U4_4GrecvLength);
  724. dblocptr->location.CSQ = (uint8_t)(CSQ[6]&0xf*10)+(CSQ[7]&0xf);
  725. memset(CSQ,0,12);
  726. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  727. }
  728. else if(strncmp((char*)U4_4GrecvBuff, "+MIPURC", strlen("+MIPURC"))==0) //监测平台回复+MIPURC:
  729. {
  730. uint8_t high_byte = (U4_4GrecvBuff[18]&0x0f) *10;
  731. uint8_t low_byte = U4_4GrecvBuff[19]&0x0f;
  732. hccd = high_byte + low_byte;
  733. memcpy(MIPurc1,&U4_4GrecvBuff[21],hccd*2);
  734. const char *hex = (const char *)MIPurc1; // 将 uint8_t * 转换为 const char *
  735. int size = strlen(hex) / 2; // 计算二进制数据的长度
  736. unsigned char *bin = (unsigned char *)malloc(size); // 分配足够的内存用于存储二进制数据
  737. rlt = hex2bin(bin, hex); // 调用hex2bin函数进行转换
  738. memcpy(MIPurc, bin, rlt); // 将 bin 中的 rlt 个字节复制到 MIPurc1 中 接收到的数据放入MIPurc1中
  739. free(bin); // 释放内存
  740. memset(U4_4GrecvBuff,0,BUFFER_SIZE);
  741. memset(MIPurc1,0,100);
  742. }
  743. }
  744. void MIPURCHandle(void)
  745. {
  746. #if open4G == 1
  747. if(MIPurc[0]==0x7E)
  748. {
  749. uint16_t PTXXID = MIPurc[1]<<8 | MIPurc[2]; //消息ID
  750. uint16_t xxtcLen = MIPurc[3]<<8 | MIPurc[4]; //数据长度
  751. uint16_t xxRE = MIPurc[15]<<8 | MIPurc[16]; //回复ID
  752. uint8_t YESorNO = MIPurc[17]; //00 success ; 01 fail
  753. if(PTXXID==XXID_pttyyd) //收到平台通用应答0x8001
  754. {
  755. if(xxRE == MessageID_authentication)//回复鉴权ID
  756. {
  757. if(YESorNO==YES)
  758. {
  759. printf("@鉴权应答yes\r\n");
  760. authFlag = true;
  761. Offline=false; //待判定假消息
  762. Online = true; //待判定假消息
  763. uploaweork=true;
  764. }
  765. else if(YESorNO==NO)
  766. {
  767. printf("@鉴权应答no\r\n");
  768. }
  769. memset(MIPurc,0,rlt);//rlt下发长度
  770. }
  771. else if(xxRE == MessageID_heartbeat)//回复鉴权ID
  772. {
  773. if(YESorNO==YES)
  774. {
  775. printf("@心跳应答yes\r\n");
  776. printf("@TCP连接成功!!\r\n");
  777. }
  778. else if(YESorNO==NO)
  779. {
  780. printf("@心跳应答no\r\n");
  781. }
  782. memset(MIPurc,0,rlt);//rlt下发长度
  783. }
  784. else if(xxRE == MessageID_location)//回复鉴权ID
  785. {
  786. if(YESorNO==YES)
  787. {
  788. printf("@地址应答yes\r\n");
  789. }
  790. else if(YESorNO==NO)
  791. {
  792. printf("@地址应答no\r\n");
  793. }
  794. memset(MIPurc,0,rlt);//rlt下发长度
  795. }
  796. else if(xxRE == MessageID_Getauth)//获取权限
  797. {
  798. if(YESorNO==YES)
  799. {
  800. printf("@权限应答yes\r\n");
  801. reAuth=true;
  802. }
  803. else if(YESorNO==NO)
  804. {
  805. printf("@权限应答no\r\n");
  806. reAuth=false;
  807. }
  808. memset(MIPurc,0,rlt);//rlt下发长度
  809. }
  810. }
  811. else if(PTXXID == XXID_ptxxtc) //收到平台消息透传 8900
  812. {
  813. authFlag = true;
  814. Offline=false; //待判定假消息
  815. Online = true; //待判定假消息
  816. uploaweork=true;
  817. uint8_t tcsjLen = MIPurc[13];
  818. memcpy(MIPurcXXTCSJ,&MIPurc[13],xxtcLen);
  819. printf("@得到透传数据,%d\r\n",tcsjLen);
  820. memset(MIPurc,0,rlt);//rlt下发长度
  821. }
  822. }
  823. else if(authFlag)
  824. {
  825. authFlag = false;
  826. HAL_Delay(500);
  827. uint8_t test[] = {0x05}; //test心跳
  828. tt808FsFunc(test,1,MessageID_heartbeat); //test心跳
  829. }
  830. #endif
  831. else if(reIME)
  832. {
  833. reIME=false;
  834. phonenum[0] = DTUurc[0]<<8|DTUurc[1];
  835. phonenum[1] = DTUurc[2]<<8|DTUurc[3];
  836. phonenum[2] = DTUurc[4]<<8|DTUurc[5];
  837. phonenull =false;
  838. Flash_WriteBytes(phonenum,phoneNumADDR,3);//更新ime
  839. //memset(DTUurc,0,100);
  840. printf("IMEI设置完成\r\n");
  841. printf("即将重启\r\n");
  842. wdiFlag = true;
  843. }
  844. }
  845. time_t timestamp ;
  846. void time_bj(void)
  847. {
  848. struct tm timeinfo;
  849. timeinfo.tm_year = tt808.Rtime[0]+2000-1900;
  850. timeinfo.tm_mon = tt808.Rtime[1]-1;
  851. timeinfo.tm_mday = tt808.Rtime[2];
  852. timeinfo.tm_hour = tt808.Rtime[3]-8;
  853. timeinfo.tm_min = tt808.Rtime[4];
  854. timeinfo.tm_sec = tt808.Rtime[5];
  855. timestamp = mktime(&timeinfo);
  856. dblocptr->location.timeStamp = timestamp;
  857. }
  858. void ReU4Proces(void)
  859. {
  860. if(GnssFlag)
  861. {
  862. GnssFlag=false;
  863. RTCtime();//同步时间
  864. // 调用函数提取字符串
  865. extractString(MGNSSLOC, cSpeed,7 ,8);//采集
  866. dSpeed = convertToDouble(cSpeed); //转换浮点数
  867. dSpeed*=10;
  868. // 调用函数提取字符串
  869. extractString(MGNSSLOC, clatitude,1 ,2);//采集
  870. dlatitude = convertToDouble(clatitude); //转换浮点数
  871. uint32_t latitudetemp=convertGPS(dlatitude);
  872. dblocptr->location.latitudeH = (latitudetemp>>16)&0xFFFF;
  873. dblocptr->location.latitudeH = swapBytes16(dblocptr->location.latitudeH);//转换H字节
  874. dblocptr->location.latitudeL = (latitudetemp)&0xFFFF;
  875. dblocptr->location.latitudeL = swapBytes16(dblocptr->location.latitudeL);//转换L字节
  876. extractString(MGNSSLOC, clongitude,2 ,3);//采集
  877. dlongitude = convertToDouble(clongitude); //转换浮点数
  878. uint32_t longitudetemp=convertGPS(dlongitude);
  879. dblocptr->location.longitudeH = (longitudetemp>>16)&0xFFFF;
  880. dblocptr->location.longitudeH = swapBytes16(dblocptr->location.longitudeH);//转换H字节
  881. dblocptr->location.longitudeL = (longitudetemp)&0xFFFF;
  882. dblocptr->location.longitudeL = swapBytes16(dblocptr->location.longitudeL);//转换L字节
  883. // printf("%d\r\n",dblocptr->location.latitude);
  884. // printf("%d\r\n",dblocptr->location.longitude);
  885. // printf("%08X\r\n",dblocptr->location.latitude);
  886. // printf("%08X\r\n",dblocptr->location.longitude);
  887. extractString(MGNSSLOC, csatellitesNum,10 ,11);//采集卫星个数
  888. dblocptr->location.satellitesNum = convertToDouble(csatellitesNum); //转换浮点数
  889. //printf("%d",tt808.satellitesNum);
  890. dblocptr->location.speed = (uint16_t)dSpeed;
  891. memset(MGNSSLOC,0,100);
  892. }
  893. }
  894. //*离线蓝牙锁