Global.cpp 36 KB

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