Global.cpp 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882
  1. #include "pch.h"
  2. #include "Global.h"
  3. #include <SetupAPI.h>
  4. #include <InitGuid.h>
  5. #include <WinIoCtl.h>
  6. #pragma comment(lib, "SetupAPI.lib")
  7. namespace Global
  8. {
  9. //////////////////////////////////////////////////////////////////////////
  10. // 全局变量;
  11. BOOL g_bTestHost = FALSE;
  12. TCHAR g_szCurModuleDir[MAX_PATH] = { 0 };
  13. TCHAR g_szCurModulePath[MAX_PATH] = { 0 };
  14. TCHAR g_szFna[MAX_PATH] = { 0 };
  15. TCHAR g_szConfig[MAX_PATH] = { 0 };
  16. std::string g_strMacs;
  17. std::vector<MacAddress> g_vtMac;
  18. TConfig g_tConfig;
  19. Global::TChassis g_AutoOnlineChassis;
  20. // usb;
  21. static GUID UsbClassGuid = { 0xA5DCBF10L, 0x6530, 0x11D2, {0x90, 0x1F, 0x00, 0xC0, 0x4F, 0xB9, 0x51, 0xED} };
  22. // mac;
  23. static GUID MacClassGuid = { 0xAD498944, 0x762F, 0x11D0, {0x8D, 0xCB, 0x00, 0xC0, 0x4F, 0xC3, 0x35, 0x8C} };
  24. // hdd;
  25. static GUID HDDClassGuid = { 0x53F56307, 0xB6BF, 0x11D0, {0x94, 0xF2, 0x00, 0xA0, 0xC9, 0x1E, 0xFB, 0x8B} };
  26. //////////////////////////////////////////////////////////////////////////
  27. // 全局函数;
  28. /************************************************************************/
  29. /* 函数:WriteTextLog[7/28/2009 Jeff];
  30. /* 描述:写文本日志;
  31. /* 参数:;
  32. /* [IN] :;
  33. /* 返回:void;
  34. /* 注意:;
  35. /* 示例:;
  36. /*
  37. /* 修改:;
  38. /* 日期:;
  39. /* 内容:;
  40. /************************************************************************/
  41. void WriteTextLog(const TCHAR* format, ...)
  42. {
  43. if (Global::g_tConfig.com.size() == 0)
  44. {
  45. return;
  46. }
  47. // 将日志内容输入到文件中;
  48. // 获取今年年份;
  49. __time64_t gmt = time(NULL); // 获取当前日历时间(1900-01-01开始的Unix时间戳);
  50. struct tm gmtm = { 0 };
  51. localtime_s(&gmtm, &gmt); // 时间戳转成本地时间;
  52. // 解析出日志路径;
  53. TCHAR szlogpath[MAX_PATH] = { 0 };
  54. _stprintf_s(szlogpath, _T("%slog\\Serial Port%s Log %02d%02d.txt"), g_szCurModuleDir, Global::g_tConfig.com.substr(3, 1).c_str(), gmtm.tm_mon + 1, gmtm.tm_mday);
  55. // 打开或创建文件;
  56. FILE* fp = NULL;
  57. //if (_taccess(szlogpath, 0) != -1)
  58. #ifndef UNICODE
  59. if (_access(szlogpath, 0) != -1)
  60. #else
  61. if (_taccess(szlogpath, 0) != -1)
  62. #endif
  63. { // 存在;
  64. if (0 == _tfopen_s(&fp, szlogpath, _T("a+")))
  65. // 移动到末尾;
  66. fseek(fp, 0, SEEK_END);
  67. }
  68. else
  69. { // 不存在;
  70. _tfopen_s(&fp, szlogpath, _T("w+"));
  71. }
  72. if (fp == NULL)
  73. return;
  74. // 格式化前设置语言区域;
  75. TCHAR* old_locale = _tcsdup(_tsetlocale(LC_CTYPE, NULL));
  76. _tsetlocale(LC_CTYPE, _T("chs")); //设定中文;
  77. // 格式化日志内容;
  78. va_list args = NULL;
  79. int len = 0;
  80. TCHAR* buffer = NULL;
  81. va_start(args, format);
  82. // _vscprintf doesn't count. terminating '\0'
  83. len = _vsctprintf(format, args) + 1;
  84. buffer = (TCHAR*)malloc(len * sizeof(TCHAR));
  85. _vstprintf_s(buffer, len, format, args);
  86. _ftprintf(fp, _T("%04d-%02d-%02d %02d:%02d:%02d %s\n"), gmtm.tm_year + 1990, gmtm.tm_mon + 1, gmtm.tm_mday, gmtm.tm_hour, gmtm.tm_min, gmtm.tm_sec, buffer);
  87. // 关闭文件,释放资源并设置回原语言区域;
  88. free(buffer);
  89. fclose(fp);
  90. _tsetlocale(LC_CTYPE, old_locale);
  91. free(old_locale); //还原区域设定;
  92. }
  93. void WriteReportLog(int type, std::string des, const TCHAR* format, ...)
  94. {
  95. if (Global::g_tConfig.com.size() == 0)
  96. return;
  97. TCHAR* old_locale = _tcsdup(_tsetlocale(LC_CTYPE, NULL));
  98. _tsetlocale(LC_CTYPE, _T("chs")); //设定中文;
  99. // 格式化日志内容;
  100. va_list args = NULL;
  101. int len = 0;
  102. TCHAR* buffer = NULL;
  103. va_start(args, format);
  104. // _vscprintf doesn't count. terminating '\0'
  105. len = _vsctprintf(format, args) + 1;
  106. buffer = (TCHAR*)malloc(len * sizeof(TCHAR));
  107. if (buffer == NULL)
  108. {
  109. _tsetlocale(LC_CTYPE, old_locale);
  110. free(old_locale); //还原区域设定;
  111. return;
  112. }
  113. _vstprintf_s(buffer, len, format, args);
  114. std::map<std::string, std::string> report_data;
  115. report_data.insert(std::pair<std::string, std::string>(des, buffer));
  116. if ( type == 0 )
  117. g_db.InsertReportInfo("NetWork", report_data);
  118. else if ( type == 1 )
  119. g_db.InsertReportInfo("Serial", report_data);
  120. // 关闭文件,释放资源并设置回原语言区域;
  121. free(buffer);
  122. _tsetlocale(LC_CTYPE, old_locale);
  123. free(old_locale); //还原区域设定;
  124. }
  125. // 读取配置文件-预留;
  126. void GetConfig()
  127. {
  128. // 读取文件;
  129. FILE* pf = NULL;
  130. _tfopen_s(&pf, _T("./Config.json"), _T("rb"));
  131. if (!pf)
  132. return;
  133. // 获取文件长度;
  134. fseek(pf, 0, SEEK_END);
  135. size_t file_size = ftell(pf);
  136. fseek(pf, 0, SEEK_SET);
  137. // 读取文件内容;
  138. byte* pdata = (byte*)malloc(file_size);
  139. fread(pdata, file_size, 1, pf);
  140. fclose(pf);
  141. // Json数据;
  142. cJSON* pJson = cJSON_Parse((const char*)pdata);
  143. if (pJson == NULL)
  144. {
  145. goto end;
  146. }
  147. // 获取数据;
  148. g_tConfig.com = cJSON_GetObjectItem(pJson, _T("COM")) ? cJSON_GetObjectItem(pJson, _T("COM"))->valuestring : "";
  149. g_tConfig.baudrate = cJSON_GetObjectItem(pJson, _T("Baudrate")) ? cJSON_GetObjectItem(pJson, _T("Baudrate"))->valuestring : "115200";
  150. g_tConfig.mode = cJSON_GetObjectItem(pJson, _T("Mode")) ? cJSON_GetObjectItem(pJson, _T("Mode"))->valueint : 0;
  151. g_tConfig.warncount = cJSON_GetObjectItem(pJson, _T("WarnCount")) ? cJSON_GetObjectItem(pJson, _T("WarnCount"))->valueint : 200;
  152. g_tConfig.waitboot = cJSON_GetObjectItem(pJson, _T("WaitBoot")) ? cJSON_GetObjectItem(pJson, _T("WaitBoot"))->valueint : 5000;
  153. g_tConfig.serverurl = cJSON_GetObjectItem(pJson, _T("server-url")) ? cJSON_GetObjectItem(pJson, _T("server-url"))->valuestring : "";
  154. g_tConfig.chassis = cJSON_GetObjectItem(pJson, _T("Chassis")) ? cJSON_GetObjectItem(pJson, _T("Chassis"))->valuestring : "";
  155. // 频道;
  156. cJSON* pItem = NULL;
  157. cJSON* pChannel = cJSON_GetObjectItem(pJson, "Channel");
  158. if (pChannel)
  159. {
  160. int nCount = cJSON_GetArraySize(pChannel);
  161. for (int i = 0; i < nCount; i++)
  162. {
  163. pItem = cJSON_GetArrayItem(pChannel, i);
  164. if (pItem && pItem->child)
  165. {
  166. g_tConfig.channel.insert(pair<std::string, std::string>(pItem->child->string, pItem->child->valuestring));
  167. }
  168. }
  169. }
  170. // 语言;
  171. cJSON* pLanguage = cJSON_GetObjectItem(pJson, "Language");
  172. if (pLanguage)
  173. {
  174. int nCount = cJSON_GetArraySize(pLanguage);
  175. for (int i = 0; i < nCount; i++)
  176. {
  177. pItem = cJSON_GetArrayItem(pLanguage, i);
  178. if (pItem && pItem->child)
  179. {
  180. g_tConfig.language.insert(pair<std::string, std::string>(pItem->child->string, pItem->child->valuestring));
  181. }
  182. }
  183. }
  184. // 文件夹;
  185. cJSON* pKeyFolder = cJSON_GetObjectItem(pJson, "KeyFolder");
  186. if (pKeyFolder)
  187. {
  188. int nCount = cJSON_GetArraySize(pKeyFolder);
  189. for (int i = 0; i < nCount; i++)
  190. {
  191. pItem = cJSON_GetArrayItem(pKeyFolder, i);
  192. if (pItem && pItem->child)
  193. {
  194. g_tConfig.keyfolder.insert(pair<std::string, std::string>(pItem->child->string, pItem->child->valuestring));
  195. }
  196. }
  197. }
  198. // read check;
  199. cJSON *pReadCheck = cJSON_GetObjectItem(pJson, "ReadCheck");
  200. if ( pReadCheck )
  201. {
  202. g_tConfig.readcheck.IsPID = cJSON_GetObjectItem(pReadCheck, _T("PID")) ? cJSON_GetObjectItem(pReadCheck, _T("PID"))->valueint : 1;
  203. g_tConfig.readcheck.IsCHANNEL = cJSON_GetObjectItem(pReadCheck, _T("CHANNEL")) ? cJSON_GetObjectItem(pReadCheck, _T("CHANNEL"))->valueint : 1;
  204. g_tConfig.readcheck.IsOSD = cJSON_GetObjectItem(pReadCheck, _T("OSD")) ? cJSON_GetObjectItem(pReadCheck, _T("OSD"))->valueint : 1;
  205. g_tConfig.readcheck.IsSHOP = cJSON_GetObjectItem(pReadCheck, _T("SHOP")) ? cJSON_GetObjectItem(pReadCheck, _T("SHOP"))->valueint : 1;
  206. g_tConfig.readcheck.IsDID = cJSON_GetObjectItem(pReadCheck, _T("DID")) ? cJSON_GetObjectItem(pReadCheck, _T("DID"))->valueint : 1;
  207. g_tConfig.readcheck.IsMAC = cJSON_GetObjectItem(pReadCheck, _T("MAC")) ? cJSON_GetObjectItem(pReadCheck, _T("MAC"))->valueint : 1;
  208. g_tConfig.readcheck.IsHDCP = cJSON_GetObjectItem(pReadCheck, _T("HDCP")) ? cJSON_GetObjectItem(pReadCheck, _T("HDCP"))->valueint : 1;
  209. g_tConfig.readcheck.IsHDCP22 = cJSON_GetObjectItem(pReadCheck, _T("HDCP22")) ? cJSON_GetObjectItem(pReadCheck, _T("HDCP22"))->valueint : 1;
  210. g_tConfig.readcheck.IsWIDI = cJSON_GetObjectItem(pReadCheck, _T("WIDI")) ? cJSON_GetObjectItem(pReadCheck, _T("WIDI"))->valueint : 1;
  211. g_tConfig.readcheck.IsWIDEVINE = cJSON_GetObjectItem(pReadCheck, _T("WIDEVINE")) ? cJSON_GetObjectItem(pReadCheck, _T("WIDEVINE"))->valueint : 1;
  212. g_tConfig.readcheck.IsESN = cJSON_GetObjectItem(pReadCheck, _T("ESN")) ? cJSON_GetObjectItem(pReadCheck, _T("ESN"))->valueint : 1;
  213. g_tConfig.readcheck.IsCI = cJSON_GetObjectItem(pReadCheck, _T("CI")) ? cJSON_GetObjectItem(pReadCheck, _T("CI"))->valueint : 1;
  214. }
  215. #ifdef SUPER_VER
  216. // write check;
  217. cJSON* pWriteCheck = cJSON_GetObjectItem(pJson, "WriteCheck");
  218. if (pWriteCheck)
  219. {
  220. //g_tConfig.writecheck.IsPID = cJSON_GetObjectItem(pWriteCheck, _T("PID")) ? cJSON_GetObjectItem(pWriteCheck, _T("PID"))->valueint : 1;
  221. //g_tConfig.writecheck.IsCHANNEL = cJSON_GetObjectItem(pWriteCheck, _T("CHANNEL")) ? cJSON_GetObjectItem(pWriteCheck, _T("CHANNEL"))->valueint : 1;
  222. //g_tConfig.writecheck.IsOSD = cJSON_GetObjectItem(pWriteCheck, _T("OSD")) ? cJSON_GetObjectItem(pWriteCheck, _T("OSD"))->valueint : 1;
  223. //g_tConfig.writecheck.IsSHOP = cJSON_GetObjectItem(pWriteCheck, _T("SHOP")) ? cJSON_GetObjectItem(pWriteCheck, _T("SHOP"))->valueint : 1;
  224. g_tConfig.writecheck.IsDID = cJSON_GetObjectItem(pWriteCheck, _T("DID")) ? cJSON_GetObjectItem(pWriteCheck, _T("DID"))->valueint : 1;
  225. g_tConfig.writecheck.IsMAC = cJSON_GetObjectItem(pWriteCheck, _T("MAC")) ? cJSON_GetObjectItem(pWriteCheck, _T("MAC"))->valueint : 1;
  226. g_tConfig.writecheck.IsHDCP = cJSON_GetObjectItem(pWriteCheck, _T("HDCP")) ? cJSON_GetObjectItem(pWriteCheck, _T("HDCP"))->valueint : 1;
  227. g_tConfig.writecheck.IsHDCP22 = cJSON_GetObjectItem(pWriteCheck, _T("HDCP22")) ? cJSON_GetObjectItem(pWriteCheck, _T("HDCP22"))->valueint : 1;
  228. g_tConfig.writecheck.IsWIDI = cJSON_GetObjectItem(pWriteCheck, _T("WIDI")) ? cJSON_GetObjectItem(pWriteCheck, _T("WIDI"))->valueint : 1;
  229. g_tConfig.writecheck.IsWIDEVINE = cJSON_GetObjectItem(pWriteCheck, _T("WIDEVINE")) ? cJSON_GetObjectItem(pWriteCheck, _T("WIDEVINE"))->valueint : 1;
  230. g_tConfig.writecheck.IsESN = cJSON_GetObjectItem(pWriteCheck, _T("ESN")) ? cJSON_GetObjectItem(pWriteCheck, _T("ESN"))->valueint : 1;
  231. g_tConfig.writecheck.IsCI = cJSON_GetObjectItem(pWriteCheck, _T("CI")) ? cJSON_GetObjectItem(pWriteCheck, _T("CI"))->valueint : 1;
  232. }
  233. // write done;
  234. cJSON* pWriteDone = cJSON_GetObjectItem(pJson, "WriteDone");
  235. if (pWriteDone)
  236. {
  237. g_tConfig.writedone.IsPID = cJSON_GetObjectItem(pWriteDone, _T("PID")) ? cJSON_GetObjectItem(pWriteDone, _T("PID"))->valueint : 1;
  238. g_tConfig.writedone.IsCHANNEL = cJSON_GetObjectItem(pWriteDone, _T("CHANNEL")) ? cJSON_GetObjectItem(pWriteDone, _T("CHANNEL"))->valueint : 1;
  239. g_tConfig.writedone.IsOSD = cJSON_GetObjectItem(pWriteDone, _T("OSD")) ? cJSON_GetObjectItem(pWriteDone, _T("OSD"))->valueint : 1;
  240. g_tConfig.writedone.IsSHOP = cJSON_GetObjectItem(pWriteDone, _T("SHOP")) ? cJSON_GetObjectItem(pWriteDone, _T("SHOP"))->valueint : 1;
  241. g_tConfig.writedone.IsDID = cJSON_GetObjectItem(pWriteDone, _T("DID")) ? cJSON_GetObjectItem(pWriteDone, _T("DID"))->valueint : 1;
  242. g_tConfig.writedone.IsMAC = cJSON_GetObjectItem(pWriteDone, _T("MAC")) ? cJSON_GetObjectItem(pWriteDone, _T("MAC"))->valueint : 1;
  243. g_tConfig.writedone.IsHDCP = cJSON_GetObjectItem(pWriteDone, _T("HDCP")) ? cJSON_GetObjectItem(pWriteDone, _T("HDCP"))->valueint : 1;
  244. g_tConfig.writedone.IsHDCP22 = cJSON_GetObjectItem(pWriteDone, _T("HDCP22")) ? cJSON_GetObjectItem(pWriteDone, _T("HDCP22"))->valueint : 1;
  245. g_tConfig.writedone.IsWIDI = cJSON_GetObjectItem(pWriteDone, _T("WIDI")) ? cJSON_GetObjectItem(pWriteDone, _T("WIDI"))->valueint : 1;
  246. g_tConfig.writedone.IsWIDEVINE = cJSON_GetObjectItem(pWriteDone, _T("WIDEVINE")) ? cJSON_GetObjectItem(pWriteDone, _T("WIDEVINE"))->valueint : 1;
  247. g_tConfig.writedone.IsESN = cJSON_GetObjectItem(pWriteDone, _T("ESN")) ? cJSON_GetObjectItem(pWriteDone, _T("ESN"))->valueint : 1;
  248. g_tConfig.writedone.IsCI = cJSON_GetObjectItem(pWriteDone, _T("CI")) ? cJSON_GetObjectItem(pWriteDone, _T("CI"))->valueint : 1;
  249. }
  250. #endif
  251. // 配置;
  252. cJSON* pChassis = cJSON_GetObjectItem(pJson, "Chassis-list");
  253. if (pChassis)
  254. {
  255. int nCount = cJSON_GetArraySize(pChassis);
  256. for (int i = 0; i < nCount; i++)
  257. {
  258. pItem = cJSON_GetArrayItem(pChassis, i);
  259. if (pItem && pItem->child)
  260. {
  261. std::string name;
  262. TChassis tchassis;
  263. name = cJSON_GetObjectItem(pItem, _T("name")) ? cJSON_GetObjectItem(pItem, _T("name"))->valuestring : "";
  264. tchassis.IsCopyDID = cJSON_GetObjectItem(pItem, _T("IsCopyDID")) ? cJSON_GetObjectItem(pItem, _T("IsCopyDID"))->valueint : 0;
  265. tchassis.IsCopyMAC = cJSON_GetObjectItem(pItem, _T("IsCopyMAC")) ? cJSON_GetObjectItem(pItem, _T("IsCopyMAC"))->valueint : 0;
  266. tchassis.IsCopyKEY = cJSON_GetObjectItem(pItem, _T("IsCopyKEY")) ? cJSON_GetObjectItem(pItem, _T("IsCopyKEY"))->valueint : 0;
  267. tchassis.IsCopyESN = cJSON_GetObjectItem(pItem, _T("IsCopyESN")) ? cJSON_GetObjectItem(pItem, _T("IsCopyESN"))->valueint : 0;
  268. tchassis.IsCopyWiDi = cJSON_GetObjectItem(pItem, _T("IsCopyWiDi")) ? cJSON_GetObjectItem(pItem, _T("IsCopyWiDi"))->valueint : 0;
  269. tchassis.IsCopyWidevine = cJSON_GetObjectItem(pItem, _T("IsCopyWidevine")) ? cJSON_GetObjectItem(pItem, _T("IsCopyWidevine"))->valueint : 0;
  270. tchassis.IsCopyKEY2_2 = cJSON_GetObjectItem(pItem, _T("IsCopyKEY2_2")) ? cJSON_GetObjectItem(pItem, _T("IsCopyKEY2_2"))->valueint : 0;
  271. tchassis.IsCopyKEY2_3 = cJSON_GetObjectItem(pItem, _T("IsCopyKEY2_3")) ? cJSON_GetObjectItem(pItem, _T("IsCopyKEY2_3"))->valueint : 0;
  272. tchassis.IsCopyCikey = cJSON_GetObjectItem(pItem, _T("IsCopyCikey")) ? cJSON_GetObjectItem(pItem, _T("IsCopyCikey"))->valueint : 0;
  273. tchassis.IsCopyChannel = cJSON_GetObjectItem(pItem, _T("IsCopyChannel")) ? cJSON_GetObjectItem(pItem, _T("IsCopyChannel"))->valueint : 0;
  274. tchassis.IsCopyWB = cJSON_GetObjectItem(pItem, _T("IsCopyWB")) ? cJSON_GetObjectItem(pItem, _T("IsCopyWB"))->valueint : 0;
  275. tchassis.IsDisplayClientType = cJSON_GetObjectItem(pItem, _T("IsDisplayClientType")) ? cJSON_GetObjectItem(pItem, _T("IsDisplayClientType"))->valueint : 0;
  276. tchassis.IsWritePID = cJSON_GetObjectItem(pItem, _T("IsWritePID")) ? cJSON_GetObjectItem(pItem, _T("IsWritePID"))->valueint : 0;
  277. tchassis.IsWBInit = cJSON_GetObjectItem(pItem, _T("IsWBInit")) ? cJSON_GetObjectItem(pItem, _T("IsWBInit"))->valueint : 0;
  278. tchassis.IsMTKInit = cJSON_GetObjectItem(pItem, _T("IsMTKInit")) ? cJSON_GetObjectItem(pItem, _T("IsMTKInit"))->valueint : 0;
  279. tchassis.IsOsdLanguage = cJSON_GetObjectItem(pItem, _T("IsOsdLanguage")) ? cJSON_GetObjectItem(pItem, _T("IsOsdLanguage"))->valueint : 0;
  280. tchassis.IsShopLanguage = cJSON_GetObjectItem(pItem, _T("IsShopLanguage")) ? cJSON_GetObjectItem(pItem, _T("IsShopLanguage"))->valueint : 0;
  281. tchassis.IsCopyClientType = cJSON_GetObjectItem(pItem, _T("IsCopyClientType")) ? cJSON_GetObjectItem(pItem, _T("IsCopyClientType"))->valueint : 0;
  282. tchassis.IsMGKKeyEnb = cJSON_GetObjectItem(pItem, _T("IsMGKKeyEnb")) ? cJSON_GetObjectItem(pItem, _T("IsMGKKeyEnb"))->valueint : 0;
  283. tchassis.IsNovaTakHDCPEnb = cJSON_GetObjectItem(pItem, _T("IsNovaTakHDCPEnb")) ? cJSON_GetObjectItem(pItem, _T("IsNovaTakHDCPEnb"))->valueint : 0;
  284. tchassis.ProjectID = cJSON_GetObjectItem(pItem, _T("ProjectID")) ? cJSON_GetObjectItem(pItem, _T("ProjectID"))->valueint : 0;
  285. tchassis.Channel = cJSON_GetObjectItem(pItem, _T("Channel")) ? cJSON_GetObjectItem(pItem, _T("Channel"))->valuestring : "";
  286. tchassis.WBFile = cJSON_GetObjectItem(pItem, _T("WBFile")) ? cJSON_GetObjectItem(pItem, _T("WBFile"))->valuestring : "";
  287. tchassis.Delay = cJSON_GetObjectItem(pItem, _T("Delay")) ? cJSON_GetObjectItem(pItem, _T("Delay"))->valueint : 50;
  288. tchassis.CheckString = cJSON_GetObjectItem(pItem, _T("CheckString")) ? cJSON_GetObjectItem(pItem, _T("CheckString"))->valuestring : "";
  289. tchassis.ClientType = cJSON_GetObjectItem(pItem, _T("ClientType")) ? cJSON_GetObjectItem(pItem, _T("ClientType"))->valuestring : "";
  290. tchassis.MACType = cJSON_GetObjectItem(pItem, _T("MACType")) ? cJSON_GetObjectItem(pItem, _T("MACType"))->valuestring : "";
  291. tchassis.HDCPKeyType = cJSON_GetObjectItem(pItem, _T("HDCPKeyType")) ? cJSON_GetObjectItem(pItem, _T("HDCPKeyType"))->valuestring : "";
  292. tchassis.HDCPKey22Type = cJSON_GetObjectItem(pItem, _T("HDCPKey22Type")) ? cJSON_GetObjectItem(pItem, _T("HDCPKey22Type"))->valuestring : "";
  293. tchassis.HDCPKey23Type = cJSON_GetObjectItem(pItem, _T("HDCPKey23Type")) ? cJSON_GetObjectItem(pItem, _T("HDCPKey23Type"))->valuestring : "";
  294. tchassis.ESNType = cJSON_GetObjectItem(pItem, _T("ESNType")) ? cJSON_GetObjectItem(pItem, _T("ESNType"))->valuestring : "";
  295. tchassis.WiDiType = cJSON_GetObjectItem(pItem, _T("WiDiType")) ? cJSON_GetObjectItem(pItem, _T("WiDiType"))->valuestring : "";
  296. tchassis.WidevineType = cJSON_GetObjectItem(pItem, _T("WidevineType")) ? cJSON_GetObjectItem(pItem, _T("WidevineType"))->valuestring : "";
  297. tchassis.CIKeyType = cJSON_GetObjectItem(pItem, _T("CIKeyType")) ? cJSON_GetObjectItem(pItem, _T("CIKeyType"))->valuestring : "";
  298. tchassis.MGKKeyType = cJSON_GetObjectItem(pItem, _T("MGKKeyType")) ? cJSON_GetObjectItem(pItem, _T("MGKKeyType"))->valuestring : "";
  299. tchassis.NovaTakHDCPType = cJSON_GetObjectItem(pItem, _T("NovaTakHDCPType")) ? cJSON_GetObjectItem(pItem, _T("NovaTakHDCPType"))->valuestring : "";
  300. g_tConfig.chassislist.insert(std::pair<std::string, CHASSIS>(name, tchassis));
  301. }
  302. }
  303. }
  304. end:
  305. if (pdata)
  306. free(pdata);
  307. if (pJson)
  308. cJSON_Delete(pJson);
  309. }
  310. void SetConfig()
  311. {
  312. // Json数据;
  313. cJSON* pJson = cJSON_CreateObject();
  314. cJSON_AddStringToObject(pJson, "COM", g_tConfig.com.c_str());
  315. cJSON_AddStringToObject(pJson, "server-url", g_tConfig.serverurl.c_str());
  316. cJSON_AddStringToObject(pJson, "Chassis", g_tConfig.chassis.c_str());
  317. cJSON_AddNumberToObject(pJson, "Mode", g_tConfig.mode);
  318. cJSON_AddNumberToObject(pJson, "WarnCount", g_tConfig.warncount);
  319. cJSON_AddNumberToObject(pJson, "WaitBoot", g_tConfig.waitboot);
  320. cJSON_AddStringToObject(pJson, "Baudrate", g_tConfig.baudrate.c_str());
  321. // 频道;
  322. cJSON* pItem = NULL;
  323. cJSON* pChannel = cJSON_AddArrayToObject(pJson, _T("Channel"));
  324. if (pChannel)
  325. {
  326. std::map<std::string, std::string>::iterator it = g_tConfig.channel.begin();
  327. for (; it != g_tConfig.channel.end(); it++)
  328. {
  329. pItem = cJSON_AddObjectToObject(pChannel, it->first.c_str());
  330. cJSON_AddStringToObject(pItem, it->first.c_str(), it->second.c_str());
  331. }
  332. }
  333. // 语言;
  334. cJSON* pLanguage = cJSON_AddArrayToObject(pJson, _T("Language"));
  335. if (pLanguage)
  336. {
  337. std::map<std::string, std::string>::iterator it = g_tConfig.language.begin();
  338. for (; it != g_tConfig.language.end(); it++)
  339. {
  340. pItem = cJSON_AddObjectToObject(pLanguage, it->first.c_str());
  341. cJSON_AddStringToObject(pItem, it->first.c_str(), it->second.c_str());
  342. }
  343. }
  344. // 文件夹;
  345. cJSON* pKeyFolder = cJSON_AddArrayToObject(pJson, _T("KeyFolder"));
  346. if (pKeyFolder)
  347. {
  348. std::map<std::string, std::string>::iterator it = g_tConfig.keyfolder.begin();
  349. for (; it != g_tConfig.keyfolder.end(); it++)
  350. {
  351. pItem = cJSON_AddObjectToObject(pKeyFolder, it->first.c_str());
  352. cJSON_AddStringToObject(pItem, it->first.c_str(), it->second.c_str());
  353. }
  354. }
  355. // read check;
  356. cJSON* pReadCheck = cJSON_AddObjectToObject(pJson, "ReadCheck");
  357. if (pReadCheck)
  358. {
  359. cJSON_AddBoolToObject(pReadCheck, _T("PID"), g_tConfig.readcheck.IsPID);
  360. cJSON_AddBoolToObject(pReadCheck, _T("CHANNEL"), g_tConfig.readcheck.IsCHANNEL);
  361. cJSON_AddBoolToObject(pReadCheck, _T("OSD"), g_tConfig.readcheck.IsOSD);
  362. cJSON_AddBoolToObject(pReadCheck, _T("SHOP"), g_tConfig.readcheck.IsSHOP);
  363. cJSON_AddBoolToObject(pReadCheck, _T("DID"), g_tConfig.readcheck.IsDID);
  364. cJSON_AddBoolToObject(pReadCheck, _T("MAC"), g_tConfig.readcheck.IsMAC);
  365. cJSON_AddBoolToObject(pReadCheck, _T("HDCP"), g_tConfig.readcheck.IsHDCP);
  366. cJSON_AddBoolToObject(pReadCheck, _T("HDCP22"), g_tConfig.readcheck.IsHDCP22);
  367. cJSON_AddBoolToObject(pReadCheck, _T("WIDI"), g_tConfig.readcheck.IsWIDI);
  368. cJSON_AddBoolToObject(pReadCheck, _T("WIDEVINE"), g_tConfig.readcheck.IsWIDEVINE);
  369. cJSON_AddBoolToObject(pReadCheck, _T("ESN"), g_tConfig.readcheck.IsESN);
  370. cJSON_AddBoolToObject(pReadCheck, _T("CI"), g_tConfig.readcheck.IsCI);
  371. }
  372. #ifdef SUPER_VER
  373. // write check;
  374. cJSON* pWriteCheck = cJSON_AddObjectToObject(pJson, "WriteCheck");
  375. if (pWriteCheck)
  376. {
  377. //cJSON_AddBoolToObject(pWriteCheck, _T("PID"), g_tConfig.writecheck.IsPID);
  378. //cJSON_AddBoolToObject(pWriteCheck, _T("CHANNEL"), g_tConfig.writecheck.IsCHANNEL);
  379. //cJSON_AddBoolToObject(pWriteCheck, _T("OSD"), g_tConfig.writecheck.IsOSD);
  380. //cJSON_AddBoolToObject(pWriteCheck, _T("SHOP"), g_tConfig.writecheck.IsSHOP);
  381. cJSON_AddBoolToObject(pWriteCheck, _T("DID"), g_tConfig.writecheck.IsDID);
  382. cJSON_AddBoolToObject(pWriteCheck, _T("MAC"), g_tConfig.writecheck.IsMAC);
  383. cJSON_AddBoolToObject(pWriteCheck, _T("HDCP"), g_tConfig.writecheck.IsHDCP);
  384. cJSON_AddBoolToObject(pWriteCheck, _T("HDCP22"), g_tConfig.writecheck.IsHDCP22);
  385. cJSON_AddBoolToObject(pWriteCheck, _T("WIDI"), g_tConfig.writecheck.IsWIDI);
  386. cJSON_AddBoolToObject(pWriteCheck, _T("WIDEVINE"), g_tConfig.writecheck.IsWIDEVINE);
  387. cJSON_AddBoolToObject(pWriteCheck, _T("ESN"), g_tConfig.writecheck.IsESN);
  388. cJSON_AddBoolToObject(pWriteCheck, _T("CI"), g_tConfig.writecheck.IsCI);
  389. }
  390. // write done;
  391. cJSON* pWriteDone= cJSON_AddObjectToObject(pJson, "WriteDone");
  392. if (pWriteDone)
  393. {
  394. cJSON_AddBoolToObject(pWriteDone, _T("PID"), g_tConfig.writedone.IsPID);
  395. cJSON_AddBoolToObject(pWriteDone, _T("CHANNEL"), g_tConfig.writedone.IsCHANNEL);
  396. cJSON_AddBoolToObject(pWriteDone, _T("OSD"), g_tConfig.writedone.IsOSD);
  397. cJSON_AddBoolToObject(pWriteDone, _T("SHOP"), g_tConfig.writedone.IsSHOP);
  398. cJSON_AddBoolToObject(pWriteDone, _T("DID"), g_tConfig.writedone.IsDID);
  399. cJSON_AddBoolToObject(pWriteDone, _T("MAC"), g_tConfig.writedone.IsMAC);
  400. cJSON_AddBoolToObject(pWriteDone, _T("HDCP"), g_tConfig.writedone.IsHDCP);
  401. cJSON_AddBoolToObject(pWriteDone, _T("HDCP22"), g_tConfig.writedone.IsHDCP22);
  402. cJSON_AddBoolToObject(pWriteDone, _T("WIDI"), g_tConfig.writedone.IsWIDI);
  403. cJSON_AddBoolToObject(pWriteDone, _T("WIDEVINE"), g_tConfig.writedone.IsWIDEVINE);
  404. cJSON_AddBoolToObject(pWriteDone, _T("ESN"), g_tConfig.writedone.IsESN);
  405. cJSON_AddBoolToObject(pWriteDone, _T("CI"), g_tConfig.writedone.IsCI);
  406. }
  407. #endif
  408. // 配置;
  409. cJSON* pChassis = cJSON_AddArrayToObject(pJson, _T("Chassis-list"));
  410. if (pChassis)
  411. {
  412. std::map<std::string, TChassis>::iterator it = g_tConfig.chassislist.begin();
  413. for (; it != g_tConfig.chassislist.end(); it++)
  414. {
  415. pItem = cJSON_AddObjectToObject(pChassis, it->first.c_str());
  416. cJSON_AddStringToObject(pItem, _T("name"), it->first.c_str());
  417. // bool
  418. cJSON_AddBoolToObject(pItem, _T("IsCopyDID"), it->second.IsCopyDID);
  419. cJSON_AddBoolToObject(pItem, _T("IsCopyMAC"), it->second.IsCopyMAC);
  420. cJSON_AddBoolToObject(pItem, _T("IsCopyKEY"), it->second.IsCopyKEY);
  421. cJSON_AddBoolToObject(pItem, _T("IsCopyESN"), it->second.IsCopyESN);
  422. cJSON_AddBoolToObject(pItem, _T("IsCopyWiDi"), it->second.IsCopyWiDi);
  423. cJSON_AddBoolToObject(pItem, _T("IsCopyWidevine"), it->second.IsCopyWidevine);
  424. cJSON_AddBoolToObject(pItem, _T("IsCopyKEY2_2"), it->second.IsCopyKEY2_2);
  425. cJSON_AddBoolToObject(pItem, _T("IsCopyKEY2_3"), it->second.IsCopyKEY2_3);
  426. cJSON_AddBoolToObject(pItem, _T("IsCopyCikey"), it->second.IsCopyCikey);
  427. cJSON_AddBoolToObject(pItem, _T("IsCopyChannel"), it->second.IsCopyChannel);
  428. cJSON_AddBoolToObject(pItem, _T("IsCopyWB"), it->second.IsCopyWB);
  429. cJSON_AddBoolToObject(pItem, _T("IsDisplayClientType"), it->second.IsDisplayClientType);
  430. cJSON_AddBoolToObject(pItem, _T("IsWritePID"), it->second.IsWritePID);
  431. cJSON_AddBoolToObject(pItem, _T("IsWBInit"), it->second.IsWBInit);
  432. cJSON_AddBoolToObject(pItem, _T("IsMTKInit"), it->second.IsMTKInit);
  433. cJSON_AddBoolToObject(pItem, _T("IsOsdLanguage"), it->second.IsOsdLanguage);
  434. cJSON_AddBoolToObject(pItem, _T("IsShopLanguage"), it->second.IsShopLanguage);
  435. cJSON_AddBoolToObject(pItem, _T("IsCopyClientType"), it->second.IsCopyClientType);
  436. cJSON_AddBoolToObject(pItem, _T("IsMGKKeyEnb"), it->second.IsMGKKeyEnb);
  437. cJSON_AddBoolToObject(pItem, _T("IsNovaTakHDCPEnb"), it->second.IsNovaTakHDCPEnb);
  438. // ini
  439. cJSON_AddNumberToObject(pItem, _T("ProjectID"), it->second.ProjectID);
  440. cJSON_AddNumberToObject(pItem, _T("Delay"), it->second.Delay);
  441. // string
  442. cJSON_AddStringToObject(pItem, _T("Channel"), it->second.Channel.c_str());
  443. cJSON_AddStringToObject(pItem, _T("WBFile"), it->second.WBFile.c_str());
  444. cJSON_AddStringToObject(pItem, _T("CheckString"), it->second.CheckString.c_str());
  445. cJSON_AddStringToObject(pItem, _T("ClientType"), it->second.ClientType.c_str());
  446. cJSON_AddStringToObject(pItem, _T("MACType"), it->second.MACType.c_str());
  447. cJSON_AddStringToObject(pItem, _T("HDCPKeyType"), it->second.HDCPKeyType.c_str());
  448. cJSON_AddStringToObject(pItem, _T("HDCPKey22Type"), it->second.HDCPKey22Type.c_str());
  449. cJSON_AddStringToObject(pItem, _T("HDCPKey23Type"), it->second.HDCPKey23Type.c_str());
  450. cJSON_AddStringToObject(pItem, _T("ESNType"), it->second.ESNType.c_str());
  451. cJSON_AddStringToObject(pItem, _T("WiDiType"), it->second.WiDiType.c_str());
  452. cJSON_AddStringToObject(pItem, _T("WidevineType"), it->second.WidevineType.c_str());
  453. cJSON_AddStringToObject(pItem, _T("CIKeyType"), it->second.CIKeyType.c_str());
  454. cJSON_AddStringToObject(pItem, _T("MGKKeyType"), it->second.MGKKeyType.c_str());
  455. cJSON_AddStringToObject(pItem, _T("NovaTakHDCPType"), it->second.NovaTakHDCPType.c_str());
  456. }
  457. }
  458. char* pJsonText = cJSON_Print(pJson);
  459. // 保存到文件中;
  460. FILE* pf = NULL;
  461. _tfopen_s(&pf, _T("./Config.json"), _T("wb"));
  462. if (pf)
  463. {
  464. fwrite(pJsonText, _tcslen(pJsonText), 1, pf);
  465. fclose(pf);
  466. }
  467. if (pJsonText)
  468. delete[] pJsonText;
  469. cJSON_Delete(pJson);
  470. }
  471. // 去除空格;
  472. std::string& trim(std::string& str)
  473. {
  474. int nIndex = 0;
  475. while ((nIndex = str.find_first_of(' ')) != std::string::npos)
  476. str.erase(nIndex, 1);
  477. return str;
  478. }
  479. // hModule 模块句柄 NULL表示当前模块;
  480. bool GetVersion(IN const TCHAR* fname, OUT WORD* pdwFileVersion, OUT WORD* pdwProductVerion)
  481. {
  482. VS_FIXEDFILEINFO* pVi = NULL;
  483. DWORD dwHandle = 0;
  484. int size = GetFileVersionInfoSize(fname, &dwHandle);
  485. if (size > 0)
  486. {
  487. BYTE* buffer = new BYTE[size];
  488. memset(buffer, 0, size);
  489. if (GetFileVersionInfo(fname, 0, size, buffer))
  490. {
  491. if (VerQueryValue(buffer, _T("\\"), (LPVOID*)& pVi, (PUINT)& size))
  492. {
  493. pdwFileVersion[0] = HIWORD(pVi->dwFileVersionMS);
  494. pdwFileVersion[1] = LOWORD(pVi->dwFileVersionMS);
  495. pdwFileVersion[2] = HIWORD(pVi->dwFileVersionLS);
  496. pdwFileVersion[3] = LOWORD(pVi->dwFileVersionLS);
  497. pdwProductVerion[0] = HIWORD(pVi->dwProductVersionMS);
  498. pdwProductVerion[1] = LOWORD(pVi->dwProductVersionMS);
  499. pdwProductVerion[2] = HIWORD(pVi->dwProductVersionLS);
  500. pdwProductVerion[3] = LOWORD(pVi->dwProductVersionLS);
  501. delete[] buffer;
  502. return true;
  503. }
  504. }
  505. delete[] buffer;
  506. }
  507. return false;
  508. }
  509. BOOL GetVersion(IN HMODULE hModule, OUT DWORD(&dwFVArray)[4], OUT DWORD(&dwPVArray)[4])
  510. {
  511. TCHAR fname[MAX_PATH];
  512. VS_FIXEDFILEINFO* pVi;
  513. DWORD dwHandle;
  514. if (GetModuleFileName(hModule, fname, MAX_PATH))
  515. {
  516. INT nSize = GetFileVersionInfoSize(fname, &dwHandle);
  517. if (nSize > 0)
  518. {
  519. BYTE* pBuffer = new BYTE[nSize];
  520. memset(pBuffer, 0, nSize);
  521. if (GetFileVersionInfo(fname, 0, nSize, pBuffer))
  522. {
  523. if (VerQueryValue(pBuffer, _T("\\"), (LPVOID*)& pVi, (PUINT)& nSize))
  524. {
  525. dwFVArray[0] = HIWORD(pVi->dwFileVersionMS);
  526. dwFVArray[1] = LOWORD(pVi->dwFileVersionMS);
  527. dwFVArray[2] = HIWORD(pVi->dwFileVersionLS);
  528. dwFVArray[3] = LOWORD(pVi->dwFileVersionLS);
  529. dwPVArray[0] = HIWORD(pVi->dwProductVersionMS);
  530. dwPVArray[1] = LOWORD(pVi->dwProductVersionMS);
  531. dwPVArray[2] = HIWORD(pVi->dwProductVersionLS);
  532. dwPVArray[3] = LOWORD(pVi->dwProductVersionLS);
  533. delete[]pBuffer;
  534. return TRUE;
  535. }
  536. }
  537. if (pBuffer)
  538. delete[]pBuffer;
  539. }
  540. }
  541. return FALSE;
  542. }
  543. WCHAR* ASCII2UNICODE(IN LPCCH lpASCIIStr)
  544. {
  545. if (lpASCIIStr == NULL)
  546. return NULL;
  547. // 获取宽字符字节数;
  548. int cchWideChar = MultiByteToWideChar(CP_ACP, 0, lpASCIIStr, -1, NULL, 0);
  549. if (cchWideChar == 0)
  550. return NULL;
  551. // 转换成宽字符串;
  552. WCHAR* pWideChar = new WCHAR[cchWideChar + 1];
  553. memset(pWideChar, 0, sizeof(WCHAR) * (cchWideChar + 1));
  554. int nWriteNum = MultiByteToWideChar(CP_ACP, 0, lpASCIIStr, -1, pWideChar, cchWideChar);
  555. if (nWriteNum != cchWideChar)
  556. {
  557. if (pWideChar)
  558. delete[] pWideChar;
  559. return NULL;
  560. }
  561. return pWideChar;
  562. }
  563. BOOL UNICODE2UTF8(IN LPWCH lpUNICODEStr, OUT string& strResult)
  564. {
  565. if (lpUNICODEStr == NULL)
  566. return FALSE;
  567. // 获取多字节字符字节数;
  568. int cbMultiByte = WideCharToMultiByte(CP_UTF8, 0, lpUNICODEStr, -1, NULL, 0, NULL, NULL);
  569. if (cbMultiByte == 0)
  570. return FALSE;
  571. // 转换成多字节字符;
  572. CHAR* pResult = new CHAR[cbMultiByte];
  573. memset(pResult, 0, cbMultiByte);
  574. int nWriteNum = WideCharToMultiByte(CP_UTF8, 0, lpUNICODEStr, -1, pResult, cbMultiByte, NULL, NULL);
  575. if (nWriteNum != cbMultiByte)
  576. return FALSE;
  577. strResult = pResult;
  578. if (pResult)
  579. delete[] pResult;
  580. return TRUE;
  581. }
  582. BOOL ASCII2UTF8(IN LPCCH lpASCIIStr, OUT string& strResult)
  583. {
  584. // 将ASCII字符串转成UNICODE字符串;
  585. WCHAR* pWideChar = ASCII2UNICODE(lpASCIIStr);
  586. if (pWideChar == NULL)
  587. return FALSE;
  588. // 再将UICODE转成UTF8;
  589. BOOL bResult = UNICODE2UTF8(pWideChar, strResult);
  590. if (pWideChar)
  591. delete[] pWideChar;
  592. return bResult;
  593. }
  594. string EnCode_UTF8URL(IN const CHAR* pText)
  595. {
  596. string tt = "";
  597. string dd = "";
  598. ASCII2UTF8(pText, tt);
  599. size_t len = tt.length();
  600. for (size_t i = 0; i < len; i++)
  601. {
  602. if (isalnum((BYTE)tt.at(i)))
  603. {
  604. char tempbuff[2] = { 0 };
  605. sprintf_s(tempbuff, "%c", (BYTE)tt.at(i));
  606. dd.append(tempbuff);
  607. }
  608. else if (isspace((BYTE)tt.at(i)))
  609. {
  610. dd.append("+");
  611. }
  612. else
  613. {
  614. char tempbuff[4];
  615. sprintf_s(tempbuff, "%%%X%X", ((BYTE)tt.at(i)) >> 4, ((BYTE)tt.at(i)) % 16);
  616. dd.append(tempbuff);
  617. }
  618. }
  619. return dd;
  620. }
  621. void EnCode_UTF8URL(IN const CHAR* pText, OUT string& strResult)
  622. {
  623. string tt = "";
  624. ASCII2UTF8(pText, tt);
  625. size_t len = tt.length();
  626. for (size_t i = 0; i < len; i++)
  627. {
  628. if (isalnum((BYTE)tt.at(i)))
  629. {
  630. char tempbuff[2] = { 0 };
  631. sprintf_s(tempbuff, "%c", (BYTE)tt.at(i));
  632. strResult.append(tempbuff);
  633. }
  634. else if (isspace((BYTE)tt.at(i)))
  635. {
  636. strResult.append("+");
  637. }
  638. else
  639. {
  640. char tempbuff[4];
  641. sprintf_s(tempbuff, "%%%X%X", ((BYTE)tt.at(i)) >> 4, ((BYTE)tt.at(i)) % 16);
  642. strResult.append(tempbuff);
  643. }
  644. }
  645. }
  646. // 通过注册表查找系统当前串口信息;
  647. BOOL GetSysSerialPort(std::vector<std::string>& vtports)
  648. {
  649. HKEY hKey;
  650. LSTATUS lReg = 0;
  651. DWORD dwMaxValLen = 0;
  652. DWORD dwValNum = 0;
  653. lReg = RegOpenKeyExA(HKEY_LOCAL_MACHINE, "HARDWARE\\DEVICEMAP\\SERIALCOMM", 0, KEY_QUERY_VALUE, &hKey);
  654. if (lReg != ERROR_SUCCESS)
  655. {
  656. LOG4C((LOG_WARN, "Open Registry Error"));
  657. return FALSE;
  658. }
  659. lReg = RegQueryInfoKeyA(hKey, NULL, NULL, NULL, NULL, NULL, NULL, &dwValNum, &dwMaxValLen, NULL, NULL, NULL);
  660. if (lReg != ERROR_SUCCESS)
  661. {
  662. LOG4C((LOG_WARN, "Getting Key Info Error"));
  663. return FALSE;
  664. }
  665. if (vtports.size())
  666. {
  667. vtports.clear();
  668. }
  669. LPSTR lpValName, lpComNum;
  670. DWORD dwValName, dwValSize = 6;
  671. for (DWORD i = 0; i < dwValNum; i++)
  672. {
  673. dwValName = dwMaxValLen + 1;
  674. dwValSize = 6;
  675. lpValName = (LPSTR)VirtualAlloc(NULL, dwValName, MEM_COMMIT, PAGE_READWRITE);
  676. lReg = RegEnumValueA(hKey, i, lpValName, &dwValName, NULL, NULL, NULL, NULL);
  677. if ((lReg != ERROR_SUCCESS) && (lReg != ERROR_NO_MORE_ITEMS))
  678. {
  679. LOG4C((LOG_WARN, "Enum Registry Error or No More Items"));
  680. continue;
  681. }
  682. lpComNum = (LPSTR)VirtualAlloc(NULL, 6, MEM_COMMIT, PAGE_READWRITE);
  683. lReg = RegQueryValueExA(hKey, lpValName, NULL, NULL, (LPBYTE)lpComNum, &dwValSize);
  684. if (lReg != ERROR_SUCCESS)
  685. {
  686. LOG4C((LOG_WARN, "Can not get the name of the port"));
  687. continue;
  688. }
  689. vtports.push_back(lpComNum);
  690. VirtualFree(lpValName, 0, MEM_RELEASE);
  691. VirtualFree(lpComNum, 0, MEM_RELEASE);
  692. }
  693. return TRUE;
  694. }
  695. INT GetMacAddress()
  696. {
  697. HDEVINFO hDevInfo;
  698. DWORD MemberIndex, RequiredSize;
  699. SP_DEVICE_INTERFACE_DATA DeviceInterfaceData;
  700. PSP_DEVICE_INTERFACE_DETAIL_DATA DeviceInterfaceDetailData;
  701. INT nTotal = 0;
  702. INT nNICKind = 0;
  703. // 获取设备信息集;
  704. hDevInfo = SetupDiGetClassDevs(&MacClassGuid, NULL, NULL, DIGCF_PRESENT | DIGCF_INTERFACEDEVICE);
  705. if (hDevInfo == INVALID_HANDLE_VALUE)
  706. {
  707. return -1;
  708. }
  709. g_vtMac.clear();
  710. // 枚举设备信息集中所有设备;
  711. DeviceInterfaceData.cbSize = sizeof(SP_DEVICE_INTERFACE_DATA);
  712. for (MemberIndex = 0; SetupDiEnumDeviceInterfaces(hDevInfo, NULL, &MacClassGuid, MemberIndex, &DeviceInterfaceData); MemberIndex++)
  713. {
  714. // 获取接收缓冲区大小,函数返回值为FALSE,GetLastError()=ERROR_INSUFFICIENT_BUFFER;
  715. SetupDiGetDeviceInterfaceDetail(hDevInfo, &DeviceInterfaceData, NULL, 0, &RequiredSize, NULL);
  716. // 申请接收缓冲区;
  717. DeviceInterfaceDetailData = (PSP_DEVICE_INTERFACE_DETAIL_DATA)malloc(RequiredSize);
  718. if ( DeviceInterfaceDetailData == NULL)
  719. continue;
  720. DeviceInterfaceDetailData->cbSize = sizeof(SP_DEVICE_INTERFACE_DETAIL_DATA);
  721. // 获取设备细节信息;
  722. if (SetupDiGetDeviceInterfaceDetail(hDevInfo, &DeviceInterfaceData, DeviceInterfaceDetailData, RequiredSize, NULL, NULL))
  723. {
  724. HANDLE hDeviceFile;
  725. BOOL isOK = FALSE;
  726. if (_tcsnicmp(DeviceInterfaceDetailData->DevicePath + 4, TEXT("pci"), 3) != 0)
  727. {
  728. free(DeviceInterfaceDetailData);
  729. DeviceInterfaceDetailData = NULL;
  730. continue;
  731. }
  732. MacAddress tagMacAddress;
  733. tagMacAddress.nNICKind = NIC_PCI;
  734. _stprintf_s(tagMacAddress.szNICKind, _T("%s"), _T("NIC_PCI"));
  735. // 获取设备句柄;
  736. hDeviceFile = CreateFile(DeviceInterfaceDetailData->DevicePath,
  737. 0,
  738. FILE_SHARE_READ | FILE_SHARE_WRITE,
  739. NULL,
  740. OPEN_EXISTING,
  741. 0,
  742. NULL);
  743. if (hDeviceFile != INVALID_HANDLE_VALUE)
  744. {
  745. ULONG dwID;
  746. BYTE ucData[8];
  747. DWORD dwByteRet;
  748. // 获取原生MAC地址;
  749. dwID = OID_802_3_PERMANENT_ADDRESS;
  750. isOK = DeviceIoControl(hDeviceFile, IOCTL_NDIS_QUERY_GLOBAL_STATS, &dwID, sizeof(dwID), ucData, sizeof(ucData), &dwByteRet, NULL);
  751. if (isOK)
  752. {
  753. ++nTotal;
  754. _stprintf_s(tagMacAddress.szDevicePath, _T("%s"), DeviceInterfaceDetailData->DevicePath);
  755. memset(tagMacAddress.szMacAddress, 0, sizeof(TCHAR) * MAX_PATH);
  756. // 将字节数组转换成16进制字符串;
  757. for (DWORD i = 0; i < dwByteRet; i++)
  758. {
  759. _stprintf_s(&tagMacAddress.szMacAddress[i * 3], MAX_PATH - (i * 3), (i != dwByteRet - 1) ? _T("%02X-") : _T("%02X"), ucData[i]);
  760. }
  761. g_vtMac.push_back(tagMacAddress);
  762. }
  763. CloseHandle(hDeviceFile);
  764. }
  765. }
  766. free(DeviceInterfaceDetailData);
  767. DeviceInterfaceDetailData = NULL;
  768. }
  769. SetupDiDestroyDeviceInfoList(hDevInfo);
  770. #if 1
  771. g_strMacs.clear();
  772. std::vector<MacAddress>::iterator it = g_vtMac.begin();
  773. for (; it != g_vtMac.end(); it++)
  774. {
  775. g_strMacs.append(it->szMacAddress);
  776. g_strMacs.append("&");
  777. }
  778. #endif
  779. return nTotal;
  780. }
  781. BOOL IsValidString(LPCTSTR lpszString)
  782. {
  783. if (lpszString == NULL)
  784. return FALSE;
  785. do
  786. {
  787. // ASCII可显示的字符;
  788. if (*lpszString < 32 || *lpszString > 126)
  789. {
  790. return FALSE;
  791. }
  792. } while (*++lpszString);
  793. return TRUE;
  794. }
  795. } // namespace Global