idcer_impl.cpp 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679
  1. // dllmain.cpp : 定义 DLL 应用程序的入口点。
  2. #include "stdafx.h"
  3. #include "idcer_impl.h"
  4. #include <cstring>
  5. #include <cstdio>
  6. #include "log4vendor.h"
  7. #include <path.h>
  8. #ifdef RVC_OS_WIN
  9. #include <direct.h>
  10. #define GetCurrentDir _getcwd
  11. #else
  12. #define GetCurrentDir getcwd
  13. #endif // RVC_OS_WIN
  14. #define w 102 //头像宽度
  15. #define h 126 //头像高度
  16. #define DEFAULT_URL "http://localhost:8080/avs/imitate/simulateData"
  17. string get_current_directory() {
  18. char buff[256];
  19. GetCurrentDir(buff, 256);
  20. string current_working_directory(buff);
  21. return current_working_directory;
  22. }
  23. //string GetLocalIP()
  24. //{
  25. // hostent* ent = gethostbyname(NULL);
  26. // if (ent && ent->h_addr_list[0] != NULL)
  27. // {
  28. // int i = 0;
  29. // for (; ent->h_addr_list[i] != NULL; ++i)
  30. // {
  31. // struct in_addr* in = (struct in_addr*)ent->h_addr_list[i];
  32. // if (in->S_un.S_un_b.s_b1 == 99 || in->S_un.S_un_b.s_b1 == 10)
  33. // break;
  34. // }
  35. //
  36. // if (ent->h_addr_list[i] == NULL)
  37. // i = 0;
  38. //
  39. // auto in = (struct in_addr*)ent->h_addr_list[i];
  40. // char xIP[64] = {};
  41. // sprintf(xIP, "%d.%d.%d.%d", in->S_un.S_un_b.s_b1, in->S_un.S_un_b.s_b2, in->S_un.S_un_b.s_b3, in->S_un.S_un_b.s_b4);
  42. // LOG4VTM(INFO, "ip:" << xIP);
  43. //
  44. // return string(xIP);
  45. // }
  46. //}
  47. typedef unsigned short UINT16;
  48. typedef unsigned char UINT8;
  49. #ifdef RVC_OS_WIN
  50. char* ConvertGBKToUtf8(const char* gbk, int* n)
  51. {
  52. int len = MultiByteToWideChar(CP_ACP, 0, gbk, -1, NULL, 0);
  53. WCHAR* wszGBK = new WCHAR[len + 1];
  54. memset(wszGBK, 0, len * 2 + 2);
  55. MultiByteToWideChar(CP_ACP, 0, gbk, -1, wszGBK, len);
  56. len = WideCharToMultiByte(CP_UTF8, 0, wszGBK, -1, NULL, 0, NULL, NULL);
  57. char* szUtf8 = new char[len + 1];
  58. memset(szUtf8, 0, len + 1);
  59. WideCharToMultiByte(CP_UTF8, 0, wszGBK, -1, szUtf8, len, NULL, NULL);
  60. delete[] wszGBK;
  61. *n = len - 1;
  62. return szUtf8;
  63. }
  64. void ConvertGBKToUtf8(std::string& str)
  65. {
  66. int len = 0;
  67. char* dst = ConvertGBKToUtf8(str.c_str(), &len);
  68. str = dst;
  69. delete[] dst;
  70. }
  71. #endif // RVC_OS_WIN
  72. bool UTF8_to_UCS2(const UINT8* UINT8_code, UINT16* ucs2_code)
  73. {
  74. UINT16 temp1, temp2;
  75. bool is_unrecognized = false;
  76. UINT8* in = (UINT8*)UINT8_code;
  77. if (!UINT8_code || !ucs2_code)
  78. {
  79. return is_unrecognized;
  80. }
  81. while (*in != 0)
  82. {
  83. //1字节 0xxxxxxx
  84. //0x80=1000,0000,判断最高位是否为0,如果为0,那么是ASCII字符
  85. //不需要处理,直接拷贝即可
  86. if (0x00 == (*in & 0x80))
  87. {
  88. /* 1 byte UTF-8 Charater.*/
  89. *ucs2_code = *in;
  90. is_unrecognized = true;
  91. in += 1;
  92. }
  93. //2字节 110xxxxx 10xxxxxx
  94. //0xe0=1110,0000
  95. //0xc0=1100,0000
  96. else if (0xc0 == (*in & 0xe0) && 0x80 == (*(in + 1) & 0xc0))
  97. {
  98. /* 2 bytes UTF-8 Charater.*/
  99. //0x1f=0001,1111,获得第一个字节的后5位
  100. temp1 = (UINT16)(*in & 0x1f);
  101. //左移6位
  102. temp1 <<= 6;
  103. //0x3f=0011,1111,获得第二个字节的后6位
  104. //加上上面的5位一共有11位
  105. temp1 |= (UINT16)(*(in + 1) & 0x3f);
  106. *ucs2_code = temp1;
  107. is_unrecognized = true;
  108. in += 2;
  109. }
  110. //3字节 1110xxxx 10xxxxxx 10xxxxxx
  111. //中文要进入这一个分支
  112. else if (0xe0 == (*in & 0xf0) &&
  113. 0x80 == (*(in + 1) & 0xc0) &&
  114. 0x80 == (*(in + 2) & 0xc0)
  115. )
  116. {
  117. /* 3bytes UTF-8 Charater.*/
  118. //0x0f=0000,1111
  119. //取出第一个字节的低4位
  120. temp1 = (UINT16)(*in & 0x0f);
  121. temp1 <<= 12;
  122. //0x3f=0011,1111
  123. //取得第二个字节的低6位
  124. temp2 = (UINT16)(*(in + 1) & 0x3F);
  125. temp2 <<= 6;
  126. //取得第三个字节的低6位,最后组成16位
  127. temp1 = temp1 | temp2 | (UINT16)(*(in + 2) & 0x3F);
  128. *ucs2_code = temp1;
  129. //移动到下一个字符
  130. in += 3;
  131. is_unrecognized = true;
  132. }
  133. else
  134. {
  135. /* unrecognize byte. */
  136. *ucs2_code = 0x22e0;
  137. is_unrecognized = false;
  138. //直接退出循环
  139. break;
  140. }
  141. ucs2_code += 1;
  142. }
  143. return is_unrecognized;
  144. }
  145. std::string current_working_directory()
  146. {
  147. char buff[250];
  148. GetCurrentDir(buff, 250);
  149. std::string current_working_directory(buff);
  150. return current_working_directory;
  151. }
  152. void WriteBMP(char* img, const char* filename)
  153. {
  154. int l = (w * 3 + 3) / 4 * 4;
  155. int bmi[] = {
  156. l * h + 54,0,54,40,w,h,1 | 3 * 8 << 16,0,l * h,0,0,100,0 };
  157. FILE* fp = fopen(filename, "wb");
  158. fprintf(fp, "BM");
  159. fwrite(&bmi, 52, 1, fp);
  160. fwrite(img, 1, l * h, fp);
  161. fclose(fp);
  162. }
  163. IDCerClassImpl::IDCerClassImpl()
  164. :m_mode(0)
  165. {
  166. lastErrMsg = "";
  167. }
  168. IDCerClassImpl::~IDCerClassImpl()
  169. {
  170. }
  171. ErrorCodeEnum IDCerClassImpl::GetDevCategory(DevCategoryInfo& devCategory)
  172. {
  173. ErrorCodeEnum err = Error_Succeed;
  174. err = Error_Unexpect;
  175. lastErrMsg = "{\"Description\": \"测试模式,获取适配器信息失败\"}";
  176. return err;
  177. strcpy(devCategory.szModel, "STYLE=IG#FUNCTION=ITF#CODE=UCS2");
  178. strcpy(devCategory.szType, "szCategory");
  179. strcpy(devCategory.szVendor, "szVendor=cmbszSimulator");
  180. return err;
  181. }
  182. ErrorCodeEnum IDCerClassImpl::Reset()
  183. {
  184. ErrorCodeEnum err = Error_Succeed;
  185. m_mode = 0;
  186. return err;
  187. }
  188. ErrorCodeEnum IDCerClassImpl::IDCerAuthenticate()
  189. {
  190. ErrorCodeEnum err = Error_Succeed;
  191. /*bool flag = authHttpFunction();
  192. m_mode = 0;
  193. if (!flag)
  194. {
  195. err = Error_Dev_IDCardNotFound;
  196. lastErrMsg = "未识别到身份证件";
  197. }*/
  198. SimulatorCommonAns ans;
  199. err = SimulatorHttpFunction("IDCertificate", "IDCerAuthenticate", ans);
  200. return err;
  201. }
  202. ErrorCodeEnum IDCerClassImpl::ForceIDEject()
  203. {
  204. ErrorCodeEnum err = Error_Succeed;
  205. m_mode = 0;
  206. return err;
  207. }
  208. ErrorCodeEnum IDCerClassImpl::ScanIDAndSaveImage()
  209. {
  210. ErrorCodeEnum err = Error_NotImpl;
  211. m_mode = 0;
  212. SimulatorCommonAns ans;
  213. err = SimulatorHttpFunction("IDCertificate", "ScanIDAndSaveImage", ans);
  214. return err;
  215. }
  216. ErrorCodeEnum IDCerClassImpl::QueryCardPos(int& pos)
  217. {
  218. ErrorCodeEnum err = Error_Succeed;
  219. m_mode = 0;
  220. SimulatorCommonAns ans;
  221. err = SimulatorHttpFunction("IDCertificate", "QueryCardPos", ans);
  222. return err;
  223. }
  224. ErrorCodeEnum IDCerClassImpl::IDCerRFControl(bool bControl)
  225. {
  226. ErrorCodeEnum err = Error_Succeed;
  227. m_mode = 0;
  228. if (!bControl)
  229. {
  230. SimulatorCommonAns ans;
  231. err = SimulatorHttpFunction("IDCertificate", "IDCerRFControl", ans);
  232. }
  233. return err;
  234. }
  235. ErrorCodeEnum IDCerClassImpl::DevOpen(DWORD dwPort)
  236. {
  237. depCfgPath = get_current_directory() + SPLIT_SLASH_STR + "dep" + SPLIT_SLASH_STR + "cmbsz.ini";
  238. bool ret = iniRead.ReadConfig(depCfgPath);
  239. if (ret == false)
  240. {
  241. LOG4VTM(INFO, "dep ReadConfig is Error,cfg=" << depCfgPath);
  242. }
  243. ErrorCodeEnum err = Error_Succeed;
  244. return err;
  245. }
  246. ErrorCodeEnum IDCerClassImpl::DevClose()
  247. {
  248. ErrorCodeEnum err = Error_Succeed;
  249. return err;
  250. }
  251. ErrorCodeEnum IDCerClassImpl::IDCerGetData(IDCerInfo& idCerInfo)
  252. {
  253. ErrorCodeEnum err = Error_Succeed;
  254. memset(&idCerInfo, 0, sizeof(IDCerInfo));
  255. strcpy(idCerInfo.startDate.data, "2009.03.25");
  256. idCerInfo.startDate.dwSize = strlen("2009.03.25");
  257. strcpy(idCerInfo.endDate.data, "2029.03.24");
  258. idCerInfo.endDate.dwSize = strlen("2029.03.24");
  259. return err;
  260. }
  261. ErrorCodeEnum IDCerClassImpl::IDCerGetDataEx(IDCerInfoEx& idCerInfoEx)
  262. {
  263. ErrorCodeEnum err = Error_Succeed;
  264. memset(&idCerInfoEx, 0, sizeof(IDCerInfoEx));
  265. std::string path;
  266. path = current_working_directory();
  267. path = path + "/dep/zp.bmp";
  268. char img[w * h * 3];
  269. for (int i = 0; i < w * h * 3; i++)img[i] = rand() % 256;
  270. WriteBMP(img, path.c_str());
  271. bool testRe = exHttpFunction(idCerInfoEx);
  272. return err;
  273. }
  274. ErrorCodeEnum IDCerClassImpl::IDCerGetDataEx2(IDCerInfoEx2& idCerInfoEx2)
  275. {
  276. ErrorCodeEnum err = Error_Succeed;
  277. memset(&idCerInfoEx2, 0, sizeof(IDCerInfoEx2));
  278. bool testRe = ex2HttpFunction(idCerInfoEx2);
  279. if (!testRe)
  280. {
  281. lastErrMsg = "{\"Description\": \"获取身份证芯片数据失败\"}";
  282. err = Error_Unexpect;
  283. return err;
  284. }
  285. std::string path;
  286. path = current_working_directory();
  287. path = path + "/dep/zp.bmp";
  288. char img[w * h * 3];
  289. for (int i = 0; i < w * h * 3; i++)img[i] = rand() % 256;
  290. WriteBMP(img, path.c_str());
  291. return err;
  292. }
  293. ErrorCodeEnum IDCerClassImpl::GetLastErr(DevErrorInfo& devErrInfo)
  294. {
  295. static int times = 0;
  296. char szMessage[128];
  297. //sprintf(szMessage, "这是第 %d 条错误信息", ++times);
  298. bool flag = authHttpFunction("GetLastErr");
  299. if (!flag)
  300. {
  301. lastErrMsg = "";
  302. }
  303. strcpy(devErrInfo.szErrMsg, lastErrMsg.c_str());
  304. devErrInfo.dwErrMsgLen = lastErrMsg.length();
  305. return Error_Succeed;
  306. }
  307. bool IDCerClassImpl::authHttpFunction(string depName)
  308. {
  309. IHttpFunc* client;
  310. client = create_http(HttpsLogCallBack);
  311. IDCerDevReq idCerReq;
  312. IDCerDevRet idCerRet;
  313. idCerReq.ip = GetLocalIP();
  314. idCerReq.entityName = "IDCertificate";
  315. idCerReq.method = "readAndScan";
  316. idCerReq.adapterInterName = depName.c_str();
  317. string url = GetSimulatorUrl();
  318. if (url.length() == 0)
  319. {
  320. url = DEFAULT_URL;
  321. }
  322. idCerReq.m_url = url;
  323. LOG4VTM(INFO, "请求地址:" << idCerReq.m_url.c_str());
  324. bool ret = client->Post(idCerReq, idCerRet);
  325. if (ret) {
  326. if (idCerRet.success == false)
  327. {
  328. LOG4VTM(INFO, "请求失败");
  329. return false;
  330. }
  331. if (idCerRet.result == true)
  332. {
  333. return true;
  334. }
  335. else
  336. {
  337. return false;
  338. }
  339. }
  340. else
  341. {
  342. LOG4VTM(INFO, "ret = 0, 请求失败");
  343. return false;
  344. }
  345. }
  346. bool IDCerClassImpl::exHttpFunction(IDCerInfoEx& idCerInfoEx)
  347. {
  348. IHttpFunc* client;
  349. client = create_http(HttpsLogCallBack);
  350. IDCerDevReq idCerReq;
  351. IDCerDevRet idCerRet;
  352. idCerReq.ip = GetLocalIP();
  353. idCerReq.entityName = "IDCertificate";
  354. idCerReq.method = "readAndScan";
  355. idCerReq.adapterInterName = "IDCerGetDataEx";
  356. string url = GetSimulatorUrl();
  357. if (url.length() == 0)
  358. {
  359. url = DEFAULT_URL;
  360. }
  361. idCerReq.m_url = url;
  362. LOG4VTM(INFO, "请求地址:" << idCerReq.m_url.c_str());
  363. bool ret = client->Post(idCerReq, idCerRet);
  364. if (ret) {
  365. if (!idCerRet.success)
  366. {
  367. LOG4VTM(INFO, "请求失败");
  368. return false;
  369. }
  370. std::strcpy(idCerInfoEx.name.data, idCerRet.name.c_str());
  371. idCerInfoEx.name.dwSize = strlen(idCerRet.name.c_str());
  372. std::strcpy(idCerInfoEx.sex.data, idCerRet.sex.c_str());
  373. idCerInfoEx.sex.dwSize = strlen(idCerRet.sex.c_str());
  374. std::strcpy(idCerInfoEx.nation.data, idCerRet.nation.c_str());
  375. idCerInfoEx.nation.dwSize = strlen(idCerRet.nation.c_str());
  376. std::strcpy(idCerInfoEx.birthday.data, idCerRet.birthday.c_str());
  377. idCerInfoEx.birthday.dwSize = strlen(idCerRet.birthday.c_str());
  378. std::strcpy(idCerInfoEx.address.data, idCerRet.address.c_str());
  379. idCerInfoEx.address.dwSize = strlen(idCerRet.address.c_str());
  380. if (strlen(idCerRet.idcode.c_str()) == 0)
  381. {
  382. idCerRet.idcode = "testnum00000";
  383. }
  384. std::strcpy(idCerInfoEx.idno.data, idCerRet.idcode.c_str());
  385. idCerInfoEx.idno.dwSize = strlen(idCerRet.idcode.c_str());
  386. std::strcpy(idCerInfoEx.department.data, idCerRet.department.c_str());
  387. idCerInfoEx.department.dwSize = strlen(idCerRet.department.c_str());
  388. std::strcpy(idCerInfoEx.startDate.data, idCerRet.startdate.c_str());
  389. idCerInfoEx.startDate.dwSize = strlen(idCerRet.startdate.c_str());
  390. std::strcpy(idCerInfoEx.endDate.data, idCerRet.enddate.c_str());
  391. idCerInfoEx.endDate.dwSize = strlen(idCerRet.enddate.c_str());
  392. std::strcpy(idCerInfoEx.englishName.data, idCerRet.englishname.c_str());
  393. idCerInfoEx.englishName.dwSize = strlen(idCerRet.englishname.c_str());
  394. std::strcpy(idCerInfoEx.nationality.data, idCerRet.nationality.c_str());
  395. idCerInfoEx.nationality.dwSize = strlen(idCerRet.nationality.c_str());
  396. std::strcpy(idCerInfoEx.idVersion.data, idCerRet.idversion.c_str());
  397. idCerInfoEx.idVersion.dwSize = strlen(idCerRet.idversion.c_str());
  398. std::strcpy(idCerInfoEx.idType.data, idCerRet.idtype.c_str());
  399. idCerInfoEx.idType.dwSize = strlen(idCerRet.idtype.c_str());
  400. std::strcpy(idCerInfoEx.reserved.data, idCerRet.reserved.c_str());
  401. idCerInfoEx.reserved.dwSize = strlen(idCerRet.reserved.c_str());
  402. return true;
  403. }
  404. else
  405. {
  406. LOG4VTM(INFO, "ret = 0, 请求失败");
  407. return false;
  408. }
  409. }
  410. bool IDCerClassImpl::ex2HttpFunction(IDCerInfoEx2& idCerInfoEx2)
  411. {
  412. IHttpFunc* client;
  413. client = create_http(HttpsLogCallBack);
  414. IDCerDevReq idCerReq;
  415. IDCerDevRet idCerRet;
  416. idCerReq.ip = GetLocalIP();
  417. idCerReq.entityName = "IDCertificate";
  418. idCerReq.adapterInterName = "IDCerGetDataEx2";
  419. string url = GetSimulatorUrl();
  420. if (url.length() == 0)
  421. {
  422. url = DEFAULT_URL;
  423. }
  424. idCerReq.m_url = url;
  425. LOG4VTM(INFO, "请求地址:" << idCerReq.m_url.c_str());
  426. bool ret = client->Post(idCerReq, idCerRet);
  427. if (ret) {
  428. if (!idCerRet.success)
  429. {
  430. LOG4VTM(INFO, "请求失败");
  431. return false;
  432. }
  433. if (idCerRet.name.length() <= 0)
  434. {
  435. return false;
  436. }
  437. #ifdef RVC_OS_WIN
  438. ConvertGBKToUtf8(idCerRet.name);
  439. ConvertGBKToUtf8(idCerRet.englishname);
  440. ConvertGBKToUtf8(idCerRet.sex);
  441. ConvertGBKToUtf8(idCerRet.birthday);
  442. ConvertGBKToUtf8(idCerRet.address);
  443. ConvertGBKToUtf8(idCerRet.department);
  444. ConvertGBKToUtf8(idCerRet.idcode);
  445. ConvertGBKToUtf8(idCerRet.startdate);
  446. ConvertGBKToUtf8(idCerRet.enddate);
  447. ConvertGBKToUtf8(idCerRet.nation);
  448. ConvertGBKToUtf8(idCerRet.nationality);
  449. #endif // RVC_OS_WIN
  450. char name[1024]; memset(name, 0, 1024);
  451. std::strcpy(name, idCerRet.name.c_str());
  452. UTF8_to_UCS2((UINT8*)name, (UINT16*)idCerInfoEx2.name.data);
  453. idCerInfoEx2.name.dwSize = strlen(idCerInfoEx2.name.data);
  454. char englishname[1024]; memset(englishname, 0, 1024);
  455. std::strcpy(englishname, idCerRet.englishname.c_str());
  456. UTF8_to_UCS2((UINT8*)englishname, (UINT16*)idCerInfoEx2.englishName.data);
  457. idCerInfoEx2.englishName.dwSize = strlen(idCerInfoEx2.englishName.data);
  458. char sex[1024]; memset(sex, 0, 1024);
  459. std::strcpy(sex, idCerRet.sex.c_str());
  460. UTF8_to_UCS2((UINT8*)sex, (UINT16*)idCerInfoEx2.sex.data);
  461. idCerInfoEx2.sex.dwSize = strlen(idCerInfoEx2.sex.data);
  462. char birthday[1024]; memset(birthday, 0, 1024);
  463. std::strcpy(birthday, idCerRet.birthday.c_str());
  464. UTF8_to_UCS2((UINT8*)birthday, (UINT16*)idCerInfoEx2.birthday.data);
  465. idCerInfoEx2.birthday.dwSize = strlen(idCerInfoEx2.birthday.data);
  466. char address[1024]; memset(address, 0, 1024);
  467. std::strcpy(address, idCerRet.address.c_str());
  468. UTF8_to_UCS2((UINT8*)address, (UINT16*)idCerInfoEx2.address.data);
  469. idCerInfoEx2.address.dwSize = strlen(idCerInfoEx2.address.data);
  470. char department[1024]; memset(department, 0, 1024);
  471. std::strcpy(department, idCerRet.department.c_str());
  472. UTF8_to_UCS2((UINT8*)department, (UINT16*)idCerInfoEx2.department.data);
  473. idCerInfoEx2.department.dwSize = strlen(idCerInfoEx2.department.data);
  474. char idno[1024]; memset(idno, 0, 1024);
  475. std::strcpy(idno, idCerRet.idcode.c_str());
  476. UTF8_to_UCS2((UINT8*)idno, (UINT16*)idCerInfoEx2.idno.data);
  477. idCerInfoEx2.idno.dwSize = strlen(idCerInfoEx2.idno.data);
  478. char startDate[1024]; memset(startDate, 0, 1024);
  479. std::strcpy(startDate, idCerRet.startdate.c_str());
  480. UTF8_to_UCS2((UINT8*)startDate, (UINT16*)idCerInfoEx2.startDate.data);
  481. idCerInfoEx2.startDate.dwSize = strlen(idCerInfoEx2.startDate.data);
  482. char endDate[1024]; memset(endDate, 0, 1024);
  483. std::strcpy(endDate, idCerRet.enddate.c_str());
  484. UTF8_to_UCS2((UINT8*)endDate, (UINT16*)idCerInfoEx2.endDate.data);
  485. idCerInfoEx2.endDate.dwSize = strlen(idCerInfoEx2.endDate.data);
  486. char nation[1024]; memset(nation, 0, 1024);
  487. std::strcpy(nation, idCerRet.nation.c_str());
  488. UTF8_to_UCS2((UINT8*)nation, (UINT16*)idCerInfoEx2.nation.data);
  489. idCerInfoEx2.nation.dwSize = strlen(idCerInfoEx2.nation.data);
  490. char nationality[1024]; memset(nationality, 0, 1024);
  491. std::strcpy(nationality, idCerRet.nationality.c_str());
  492. UTF8_to_UCS2((UINT8*)nationality, (UINT16*)idCerInfoEx2.nationality.data);
  493. idCerInfoEx2.nationality.dwSize = strlen(idCerInfoEx2.nationality.data);
  494. return true;
  495. }
  496. else
  497. {
  498. LOG4VTM(INFO, "ret = 0, 请求失败");
  499. return false;
  500. }
  501. }
  502. #ifdef RVC_OS_WIN
  503. BOOL APIENTRY DllMain(HMODULE hModule,
  504. DWORD ul_reason_for_call,
  505. LPVOID lpReserved
  506. )
  507. {
  508. switch (ul_reason_for_call)
  509. {
  510. case DLL_PROCESS_ATTACH:
  511. case DLL_THREAD_ATTACH:
  512. case DLL_THREAD_DETACH:
  513. case DLL_PROCESS_DETACH:
  514. break;
  515. }
  516. return TRUE;
  517. }
  518. #endif // RVC_OS_WIN
  519. DEVICEBASE_API ErrorCodeEnum CreateDevComponent(DeviceBaseClass*& pBaseObj)
  520. {
  521. pBaseObj = new IDCerClassImpl();
  522. if (pBaseObj == NULL)
  523. return Error_Resource;
  524. cmb::log_init_config config;
  525. config.dev_name = "vendor_IDCertificate";
  526. #ifdef RVC_OS_WIN
  527. config.log_dir = ("D:\\rvc\\dbg\\");
  528. #else
  529. config.log_dir = ("/opt/rvc/dbg/");
  530. #endif
  531. std::string str;
  532. cmb::log4vendor::init(config, str);
  533. printf("init after: %s\n", str.c_str());
  534. return Error_Succeed;
  535. }
  536. DEVICEBASE_API ErrorCodeEnum ReleaseDevComponent(DeviceBaseClass*& pBaseObj)
  537. {
  538. if (pBaseObj == NULL)
  539. return Error_Param;
  540. IDCerClassImpl* pTmp = (IDCerClassImpl*)(pBaseObj);
  541. delete pTmp;
  542. pTmp = NULL;
  543. pBaseObj = NULL;
  544. return Error_Succeed;
  545. }
  546. #ifdef NEWER_COMPILER_WORKAROUNDS
  547. DEVICEBASE_API ErrorCodeEnum GetDevAdapterVersion(DevSoftVersion& retVesion)
  548. {
  549. retVesion.wMajor = retVesion.wMinor = retVesion.wBuild = retVesion.wRevision = 0;
  550. return Error_Succeed;
  551. }
  552. #endif // NEWER_COMPILER_WORKAROUNDS