Regist.c 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. /**
  2. ******************************************************************************
  3. * 版 本 :V1.0.0
  4. * 作 者 :liuyanbin
  5. * 版权所有,盗版必究。
  6. * Copyright(C) All rights reserved
  7. ******************************************************************************
  8. * 历史记录
  9. * 序号 版本 变更内容 作者 日期
  10. * 1 V0.0.1 实现4G注册 刘艳斌 2023/12/20
  11. * 2 V0.0.2 实现NB注册 刘艳斌 2023/12/20
  12. * 3 V0.0.3 整合4g和nb 刘艳斌 2024/1/24
  13. *
  14. ******************************************************************************
  15. */
  16. #include "stm32f10x.h"
  17. #include "Regist.h"
  18. #include "AT.h"
  19. #include "4GAES.h"
  20. #include "ec800m.h"
  21. #include "bc260.h"
  22. #include "INflash.h"
  23. #include "sys.h"
  24. #include <stdio.h>
  25. #include <stdarg.h>
  26. #include <string.h>
  27. #include <stdlib.h>
  28. #include "cJSON.h"
  29. extern valid_data_t valid_data;
  30. #if NBFLAG
  31. uint8_t mcu_id[8]="8945809";
  32. #else
  33. uint8_t mcu_id[8]="ceshi001";
  34. #endif
  35. uint16_t Version_data = 1032;
  36. uint8_t regist_result =0;
  37. char registData[100] = {0};
  38. //uint8_t registlen=0;
  39. extern struct AT_Struct AT;
  40. unsigned char key[17]="tuorenzhinenghua";
  41. unsigned char expansionkey[15 * 16];
  42. extern Coefficient_Data flashdata;
  43. extern uint8_t register_success;
  44. //static uint8_t tcpcontextID = 1;
  45. static uint8_t tcpconnectID = 2;
  46. static char * REGIST_SERVER ="8337239yf4.yicp.fun" ; //注册服务器地址
  47. static uint16_t REGIST_PORT=22155; //端口号
  48. /**
  49. *
  50. *注册信息打包
  51. */
  52. enum Result packRegistDataAnd(uint8_t *length){
  53. enum Result result = Result_None;
  54. // int i=0;
  55. int datalen = 0;
  56. char qcciddata[31]={0};//
  57. memset(registData,0, sizeof(registData));
  58. char* dataPtr = registData+2; //dataPtr指针指向registData第三个字节
  59. //复制muid,并转化为16进制
  60. byteToHexStr(mcu_id, dataPtr, sizeof(mcu_id));
  61. memcpy(dataPtr+strlen(dataPtr),"&",1);
  62. //获取qccid
  63. AT_Clear();
  64. //get_qccid_flag=get_qccid(qcciddata);
  65. #if NBFLAG
  66. result=bc260y.query_qccid_sync(qcciddata);
  67. #endif
  68. #if _4GFLAG
  69. result=ec800m.query_qccid_sync(qcciddata);
  70. #endif
  71. if(result==Result_Failed)
  72. {
  73. return result;
  74. }
  75. //获取复制qccid
  76. memcpy(dataPtr+strlen(dataPtr),qcciddata,31);
  77. //复制版本号
  78. snprintf(dataPtr+strlen(dataPtr),10,"&%d.%03d",Version_data/1000,Version_data%1000);
  79. Log_Printf_Debug("device data:%s\r\n",dataPtr);//串口打印
  80. Log_Printf_Debug("regist data:%s\r\n",registData+2);
  81. ScheduleKey(key, expansionkey, 4, 10);//生成密钥
  82. datalen = ECBAesEncrypt((unsigned char*)dataPtr, expansionkey, 10); //2、AES 加密
  83. registData[0] = datalen>>8;//头2个字节赋值数据长度
  84. registData[1] = datalen;
  85. Log_Printf_Debug("strlendata:%d,datalen=%d\r\n",strlen(dataPtr),datalen);
  86. *length=datalen+2;
  87. return Result_Success;
  88. }
  89. /**
  90. *
  91. *注册数据解密
  92. */
  93. enum Result analysis_recvdata()
  94. {
  95. enum Result result = Result_None;
  96. char recvdata[1024]={0};
  97. uint16_t recvdata_length=0;
  98. cJSON *json = NULL,*json_productKey = NULL,*json_deviceName = NULL,*json_deviceSecret = NULL;
  99. #if NBFLAG
  100. result =bc260y.recv_with_time_sync(tcpconnectID,(uint8_t *)recvdata,&recvdata_length,10000);
  101. #endif
  102. #if _4GFLAG
  103. result =ec800m.recv_with_time_sync(tcpconnectID,(uint8_t *)recvdata,&recvdata_length,10000);
  104. #endif
  105. if(result==Result_Failed)
  106. {
  107. return result;
  108. }
  109. //memset(valid_data.buf, 0, sizeof(valid_data.buf));
  110. // memcpy(valid_data.buf,recvdata,recvdata_length);
  111. ScheduleKey(key, expansionkey, 4, 10);
  112. // valid_data.len=recvdata_length;
  113. ECBAesDecrypt((unsigned char*)recvdata,recvdata_length, expansionkey, 10);//AES 解密
  114. Log_Printf_Debug("解密数据recvdata:%s,%d,%d\r\n",recvdata,strlen(recvdata),recvdata_length);
  115. json = cJSON_Parse(recvdata);
  116. if(!json)
  117. {
  118. Log_Printf_Debug("json parse error,%s\r\n",cJSON_GetErrorPtr());
  119. cJSON_Delete(json);
  120. return Result_Failed;
  121. }else{
  122. json_deviceSecret = cJSON_GetObjectItem(json,"deviceSecret");
  123. json_productKey = cJSON_GetObjectItem(json,"productKey");
  124. json_deviceName = cJSON_GetObjectItem(json,"deviceName");
  125. Log_Printf_Debug("获取数据成功deviceSecret:%s,json_productKey:%s,deviceName:%s\r\n",json_deviceSecret->valuestring,json_productKey->valuestring,json_deviceName->valuestring);
  126. // memcpy(flashdata.deviceSecret,json_deviceSecret->valuestring,Secretsize);
  127. // memcpy(flashdata.productKey,json_productKey->valuestring,strlen(json_deviceName->valuestring));
  128. // memcpy(flashdata.deviceName,json_deviceName->valuestring,strlen(json_deviceName->valuestring));
  129. strcpy(flashdata.deviceSecret,json_deviceSecret->valuestring);
  130. strcpy(flashdata.productKey,json_productKey->valuestring);
  131. strcpy(flashdata.deviceName,json_deviceName->valuestring);
  132. memset(&register_success, 1, sizeof(register_success));
  133. cJSON_Delete(json);
  134. return Result_Success;
  135. }
  136. }
  137. #if NBFLAG
  138. uint8_t regist_Handle()
  139. {
  140. uint8_t stat,length=0;
  141. uint16_t lac,err=0;
  142. uint32_t ci=0;
  143. enum Result result = Result_None;
  144. GPIO_SetBits(WAKE_GPIO, WAKE_GPIO_Pin);
  145. bc260y.exit_sleep_sync();//退出休眠
  146. delay_ms(100);
  147. bc260y.reset();
  148. result = bc260y.set_qisde_sync(0);//关闭回显
  149. if(result==Result_Failed)
  150. {
  151. return 0;
  152. }
  153. result=bc260y.set_sleep_sync(1);//设置休眠模式
  154. if(result==Result_Failed)
  155. {
  156. return 0;
  157. }
  158. result=bc260y.set_cfun_sync(1);//设置全功能模式
  159. if(result==Result_Failed)
  160. {
  161. return 0;
  162. }
  163. result=bc260y.set_cgreg_sync(2);//设置网络状态
  164. if(result==Result_Failed)
  165. {
  166. return 0;
  167. }
  168. for(int i=0;i<20;i++){
  169. delay_ms(400);
  170. result=bc260y.query_cgreg_sync(&regist_result,&stat,&lac,&ci);//循环查询网络状态最多20次
  171. if(stat==1)
  172. {i=20;
  173. }
  174. }
  175. if(result==Result_Failed)
  176. {
  177. return 0;
  178. }
  179. if(stat==0)
  180. {
  181. Log_Printf_Debug(" stat=%d\r\n", stat);
  182. return 0;
  183. }
  184. result =(enum Result)packRegistDataAnd(&length);//数据打包
  185. if(result==Result_Failed)
  186. {
  187. return 0;
  188. }
  189. result=bc260y.close_socket_sync(tcpconnectID);//防止以前链接没断开,断开tcp链接
  190. if(result==Result_Failed)
  191. {
  192. Log_Printf_Debug(" result=%d\r\n", result);
  193. return 0;
  194. }
  195. //tcp连接流程
  196. result=bc260y.open_socket_sync(tcpconnectID,"TCP",REGIST_SERVER,REGIST_PORT,1,&err);//连接tcp
  197. if(result==Result_Failed)
  198. {
  199. Log_Printf_Debug(" result=%d\r\n", result);
  200. return 0;
  201. }
  202. result = bc260y.dataformat_sync(1);//配置发送数据格式
  203. if(result==Result_Failed)
  204. {
  205. return 0;
  206. }
  207. result =bc260y.send_sync(tcpconnectID,(uint8_t *)registData,length);//数据发送
  208. if(result==Result_Failed)
  209. {
  210. return 0;
  211. }
  212. result =analysis_recvdata();
  213. if(result==Result_Failed)
  214. {
  215. return 0;
  216. }
  217. result=bc260y.close_socket_sync(tcpconnectID);//断开tcp连接
  218. if(result==Result_Failed)
  219. {
  220. return 0;
  221. }
  222. bc260y.enter_sleep();//进入休眠状态
  223. return 1;
  224. }
  225. #endif
  226. #if _4GFLAG
  227. //4G模块注册流程
  228. uint8_t regist_Handle()
  229. {
  230. uint8_t stat,length=0;
  231. uint16_t lac,err=0;
  232. uint32_t ci=0;
  233. enum Result result = Result_None;
  234. ec800m.exit_sleep();//退出休眠
  235. delay_ms(10);
  236. result=ec800m.set_sleep_sync(1);//设置休眠模式
  237. if(result==Result_Failed)
  238. {
  239. return 0;
  240. }
  241. result=ec800m.set_cfun_sync(1);//设置全功能模式
  242. if(result==Result_Failed)
  243. {
  244. return 0;
  245. }
  246. result=ec800m.set_cgreg_sync(2);//设置网络状态
  247. if(result==Result_Failed)
  248. {
  249. return 0;
  250. }
  251. for(int i=0;i<20;i++){
  252. delay_ms(400);
  253. result=ec800m.query_cgreg_sync(&regist_result,&stat,&lac,&ci);//循环查询网络状态最多20次
  254. if(stat==1)
  255. {i=20;
  256. }
  257. }
  258. if(result==Result_Failed)
  259. {
  260. return 0;
  261. }
  262. if(stat==0)
  263. {
  264. Log_Printf_Debug(" stat=%d\r\n", stat);
  265. return 0;
  266. }
  267. //tcp连接流程
  268. result=ec800m.open_socket_sync(tcpconnectID,"TCP",REGIST_SERVER,REGIST_PORT,1,&err);//连接tcp
  269. if(result==Result_Failed)
  270. {
  271. Log_Printf_Debug(" result=%d\r\n", result);
  272. return 0;
  273. }
  274. if(result==Result_Failed)
  275. {
  276. return 0;
  277. }
  278. result =(enum Result)packRegistDataAnd(&length);//数据打包
  279. Log_Printf_Debug("data length=%d\r\n", length);
  280. if(result==Result_Failed)
  281. {
  282. return 0;
  283. }
  284. result = ec800m.set_qisde_sync(0);//关闭回显
  285. if(result==Result_Failed)
  286. {
  287. return 0;
  288. }
  289. result =ec800m.send_sync(tcpconnectID,(uint8_t *)registData,length);//数据发送
  290. if(result==Result_Failed)
  291. {
  292. return 0;
  293. }
  294. result =analysis_recvdata();
  295. if(result==Result_Failed)
  296. {
  297. return 0;
  298. }
  299. result=ec800m.close_socket_sync(tcpconnectID);//断开tcp连接
  300. if(result==Result_Failed)
  301. {
  302. return 0;
  303. }
  304. result=ec800m.set_cfun_sync(0);//设置最小功能模式
  305. if(result==Result_Failed)
  306. {
  307. return 0;
  308. }
  309. ec800m.enter_sleep();//进入休眠状态
  310. return 1;
  311. }
  312. #endif
  313. uint8_t regist_device(void)
  314. {
  315. flashdata.read_flag=0;
  316. uint8_t regist_flag=0;
  317. Log_Printf_Debug("读取前read_flag:%d\r\n",flashdata.read_flag);
  318. STMFLASH_Read(FLASH_SAVE_ADDR,(u16*)&flashdata,sizeof(flashdata));//读取flash
  319. delay_ms(10);
  320. if(flashdata.read_flag==1)
  321. {
  322. Log_Printf_Debug("读取flash成功read_flag:%d,\ndeviceSecret:%s,\n productKey:%s,\ndeviceName:%s\r\n",flashdata.read_flag,flashdata.deviceSecret,flashdata.productKey,flashdata.deviceName);
  323. return 1;
  324. }
  325. regist_flag=regist_Handle();//注册流程
  326. if(regist_flag==0)//注册流程失败不储存flash
  327. {
  328. return 0;
  329. }
  330. store();//存储到flash
  331. return 1;
  332. }