contactless.nantian.1.1.cpp 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637
  1. #include "contactless.nantian.1.1.h"
  2. #include <cstring>
  3. #include <cstdio>
  4. ContactlessCardImpl::ContactlessCardImpl()
  5. : m_mode(0)
  6. {
  7. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  8. m_ErrInfo.dwErrMsgLen = 0;
  9. m_tempStatus.eMediaPos = CI_MEDIA_NOTPRESENT;
  10. m_pTrace = new CILIXTrace(NULL, "Contactless", "Contactless_DeCard_T10N");
  11. char INIPath[100] = "";
  12. CILIX_AUX_X::CILIX_GetModuleCurPath(INIPath);
  13. strcat(INIPath, "log.nantian.ini");
  14. char log_dir[100] = "";
  15. CILIX_AUX_X::CILIX_X_INIKeyString(INIPath, "LOGConfig", "log_dir", log_dir, "/etc/nantian");
  16. char log_level[100] = "";
  17. CILIX_AUX_X::CILIX_X_INIKeyString(INIPath, "LOGConfig", "log_level", log_level, "3");
  18. cmb::log_init_config config;
  19. config.dev_name = "contactlessso";
  20. config.log_dir = log_dir;
  21. config.log_level = atoi(log_level);
  22. std::string str;
  23. cmb::log4vendor::init(config, str);
  24. LOG4VTM(WARN, "<Contactless::ContactlessCardImpl> - "
  25. << "libContactless.nantian.1.1.so v1.0.0.0");
  26. bCancelFlag = false;
  27. bDevOpen = false;
  28. pHandle = NULL;
  29. drv_CardReader = NULL;
  30. bDrvFlag = LoadDrvDll();
  31. // if (!LoadDrvDll())
  32. // return;
  33. }
  34. ContactlessCardImpl::~ContactlessCardImpl()
  35. {
  36. if (drv_CardReader)
  37. Destroy_DRV_XCardReader(drv_CardReader);
  38. if (pHandle)
  39. dlclose(pHandle);
  40. drv_CardReader = NULL;
  41. pHandle = NULL;
  42. }
  43. bool ContactlessCardImpl::LoadDrvDll()
  44. {
  45. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  46. << "Enter-");
  47. char szInIPath[1024], szNTDRVPath[1024];
  48. CILIX_AUX_X::CILIX_GetModuleCurPath(szInIPath);
  49. sprintf(szNTDRVPath, "%snantian/%s", szInIPath, "libDRV_DeCard_T10N.nantian.so");
  50. pHandle = NULL;
  51. void *pszErr = NULL;
  52. pHandle = dlopen(szNTDRVPath, RTLD_LAZY);
  53. if (!pHandle || pszErr)
  54. {
  55. m_pTrace->WriteTrace(CILIXTRACE_L_ERROR, "LoadNTDRVDLL", "加载底层库%s失败", szNTDRVPath);
  56. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  57. << "加载底层库" << szNTDRVPath << "失败");
  58. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  59. << "Exit-");
  60. return false;
  61. }
  62. Create_DRV_XCardReader = NULL;
  63. Create_DRV_XCardReader = (pCreate_DRV_XCardReader)dlsym(pHandle, "Create_DRV_XCardReader");
  64. if (Create_DRV_XCardReader == NULL)
  65. {
  66. m_pTrace->WriteTrace(CILIXTRACE_L_ERROR, "LoadNTDRVDLL", "加载底层库方法 Create_DRV_XCardReader 失败");
  67. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  68. << "加载底层库方法 Create_DRV_XCardReader 失败");
  69. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  70. << "Exit-");
  71. return false;
  72. }
  73. Destroy_DRV_XCardReader = NULL;
  74. Destroy_DRV_XCardReader = (pDestroy_DRV_XCardReader)dlsym(pHandle, "Destroy_DRV_XCardReader");
  75. if (Destroy_DRV_XCardReader == NULL)
  76. {
  77. m_pTrace->WriteTrace(CILIXTRACE_L_ERROR, "LoadNTDRVDLL", "加载底层库方法 Destroy_DRV_XCardReader 失败");
  78. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  79. << "加载底层库方法 Destroy_DRV_XCardReader 失败");
  80. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  81. << "Exit-");
  82. return false;
  83. }
  84. drv_CardReader = Create_DRV_XCardReader();
  85. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  86. << "加载底层库成功");
  87. LOG4VTM(WARN, "<Contactless::LoadDrvDll> - "
  88. << "Exit-");
  89. return true;
  90. }
  91. //DeviceBaseClass
  92. ErrorCodeEnum ContactlessCardImpl::GetDevCategory(DevCategoryInfo &devCategory)
  93. {
  94. LOG4VTM(WARN, "<Contactless::GetDevCategory> - "
  95. << "Enter-");
  96. ErrorCodeEnum err = Error_Succeed;
  97. std::strcpy(devCategory.szModel, "FWID=1.0.2");
  98. std::strcpy(devCategory.szType, "PVER=DeCard#MID=DeCard_T10N");
  99. std::strcpy(devCategory.szVendor, "nantian");
  100. LOG4VTM(WARN, "<Contactless::GetDevCategory> - "
  101. << "Exit-");
  102. return err;
  103. }
  104. ErrorCodeEnum ContactlessCardImpl::Reset()
  105. {
  106. LOG4VTM(WARN, "<Contactless::Reset> - "
  107. << "Enter-");
  108. ErrorCodeEnum err = Error_Succeed;
  109. m_mode = 0;
  110. LOG4VTM(WARN, "<Contactless::Reset> - "
  111. << "Exit-");
  112. return err;
  113. }
  114. ErrorCodeEnum ContactlessCardImpl::DevClose()
  115. {
  116. LOG4VTM(WARN, "<Contactless::DevClose> - "
  117. << "Enter-");
  118. ErrorCodeEnum err = Error_Succeed;
  119. if (!bDrvFlag)
  120. {
  121. LOG4VTM(WARN, "<Contactless::DevClose> - "
  122. << "依赖库加载失败");
  123. err = Error_NotInit;
  124. }
  125. else
  126. {
  127. int iRet = drv_CardReader->CloseDev();
  128. if (iRet != Error_Succeed)
  129. {
  130. bDevOpen = false;
  131. err = Error_DevConnFailed;
  132. LOG4VTM(WARN, "<Contactless::DevClose> - "
  133. << "执行CloseDev失败返回" << iRet);
  134. }
  135. }
  136. LOG4VTM(WARN, "<Contactless::DevClose> - "
  137. << "Exit-");
  138. return err;
  139. }
  140. ErrorCodeEnum ContactlessCardImpl::GetLastErr(DevErrorInfo &devErrInfo)
  141. {
  142. memset(devErrInfo.szErrMsg, 0, sizeof(devErrInfo.szErrMsg));
  143. devErrInfo.dwErrMsgLen = m_ErrInfo.dwErrMsgLen;
  144. memcpy(devErrInfo.szErrMsg, m_ErrInfo.szErrMsg, m_ErrInfo.dwErrMsgLen);
  145. return Error_Succeed;
  146. }
  147. DEVICEBASE_API ErrorCodeEnum CreateDevComponent(DeviceBaseClass *&baseObj)
  148. {
  149. baseObj = new ContactlessCardImpl();
  150. if (baseObj == NULL)
  151. {
  152. return Error_Resource;
  153. }
  154. else
  155. {
  156. return Error_Succeed;
  157. }
  158. }
  159. DEVICEBASE_API ErrorCodeEnum ReleaseDevComponent(DeviceBaseClass *&pBaseObj)
  160. {
  161. if (pBaseObj == NULL)
  162. {
  163. return Error_Param;
  164. }
  165. // if (ContactlessCardImpl *pTmp = dynamic_cast<ContactlessCardImpl *>(pBaseObj))
  166. // {
  167. // delete pTmp;
  168. // pTmp = NULL;
  169. // return Error_Succeed;
  170. // }
  171. delete (ContactlessCardImpl *)pBaseObj;
  172. pBaseObj = NULL;
  173. return Error_Param;
  174. }
  175. //device initialization
  176. ErrorCodeEnum ContactlessCardImpl::DevOpen(DWORD dwPort, DWORD dwBaudRate)
  177. {
  178. LOG4VTM(WARN, "<Contactless::DevOpen> - "
  179. << "Enter-");
  180. int iRet = Error_Succeed;
  181. try
  182. {
  183. if (!bDrvFlag)
  184. {
  185. LOG4VTM(WARN, "<Contactless::DevOpen> - "
  186. << "依赖库加载失败");
  187. iRet = Error_NotInit;
  188. throw iRet;
  189. }
  190. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  191. iRet = drv_CardReader->OpenDev(NULL, NULL);
  192. if (iRet != Error_Succeed)
  193. {
  194. sprintf(m_ErrInfo.szErrMsg, "Connect Device Failed.");
  195. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  196. LOG4VTM(WARN, "<Contactless::DevOpen> - "
  197. << "执行OpenDev失败返回" << iRet);
  198. bDevOpen = false;
  199. iRet = Error_DevConnFailed;
  200. throw iRet;
  201. }
  202. bDevOpen = true;
  203. }
  204. catch (int ierror)
  205. {
  206. iRet = ierror;
  207. }
  208. LOG4VTM(WARN, "<Contactless::DevOpen> - "
  209. << "Exit-");
  210. return (ErrorCodeEnum)iRet;
  211. }
  212. //
  213. // Get card reader status
  214. //
  215. ErrorCodeEnum ContactlessCardImpl::GetDevStatus(RFICReaderStatus &devStatus)
  216. {
  217. LOG4VTM(WARN, "<Contactless::GetDevStatus> - "
  218. << "Enter-");
  219. int iRet = Error_Succeed;
  220. try
  221. {
  222. if (!bDrvFlag)
  223. {
  224. LOG4VTM(WARN, "<Contactless::GetDevStatus> - "
  225. << "依赖库加载失败");
  226. iRet = Error_NotInit;
  227. throw iRet;
  228. }
  229. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  230. if (!bDevOpen)
  231. {
  232. sprintf(m_ErrInfo.szErrMsg, "Device Not Connected.");
  233. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  234. LOG4VTM(WARN, "<Contactless::GetDevStatus> - "
  235. << "设备未连接");
  236. iRet = Error_DevConnFailed;
  237. throw iRet;
  238. }
  239. char drv_Device[100] = "\0";
  240. char drv_Media[100] = "\0";
  241. char drv_Chiper[100] = "\0";
  242. char *DevStatus[100] = {NULL};
  243. DevStatus[1] = drv_Device;
  244. DevStatus[2] = drv_Media;
  245. DevStatus[4] = drv_Chiper;
  246. iRet = drv_CardReader->GetDevStatus(0, DevStatus);
  247. if (iRet != Error_Succeed)
  248. {
  249. sprintf(m_ErrInfo.szErrMsg, "Hardware Error.");
  250. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  251. LOG4VTM(WARN, "<Contactless::GetDevStatus> - "
  252. << "执行GetDevStatus失败返回" << iRet);
  253. iRet = Error_Hardware;
  254. throw iRet;
  255. }
  256. switch ((int)(drv_Media[8] - 0x30))
  257. {
  258. case MOTORCARDREADER_MEDIAPRESENT:
  259. m_tempStatus.eMediaPos = CI_MEDIA_RF;
  260. break;
  261. case MOTORCARDREADER_MEDIANOTPRESENT:
  262. m_tempStatus.eMediaPos = CI_MEDIA_NOTPRESENT;
  263. break;
  264. default:
  265. m_tempStatus.eMediaPos = CI_MEDIA_NOTPRESENT;
  266. break;
  267. }
  268. }
  269. catch (int ierror)
  270. {
  271. iRet = ierror;
  272. }
  273. devStatus = m_tempStatus;
  274. LOG4VTM(WARN, "<Contactless::GetDevStatus> - "
  275. << "Exit-");
  276. return (ErrorCodeEnum)iRet;
  277. }
  278. //
  279. // Abort current operation.
  280. //
  281. ErrorCodeEnum ContactlessCardImpl::AbortRead()
  282. {
  283. LOG4VTM(WARN, "<Contactless::AbortRead> - "
  284. << "Enter-");
  285. int iRet = Error_Succeed;
  286. try
  287. {
  288. if (!bDrvFlag)
  289. {
  290. LOG4VTM(WARN, "<Contactless::AbortRead> - "
  291. << "依赖库加载失败");
  292. iRet = Error_NotInit;
  293. throw iRet;
  294. }
  295. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  296. if (!bDevOpen)
  297. {
  298. sprintf(m_ErrInfo.szErrMsg, "Device Not Connected.");
  299. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  300. LOG4VTM(WARN, "<Contactless::AbortRead> - "
  301. << "设备未连接");
  302. iRet = Error_DevConnFailed;
  303. throw iRet;
  304. }
  305. bCancelFlag = true;
  306. }
  307. catch (int ierror)
  308. {
  309. iRet = ierror;
  310. }
  311. LOG4VTM(WARN, "<Contactless::AbortRead> - "
  312. << "Exit-");
  313. return (ErrorCodeEnum)iRet;
  314. }
  315. //
  316. // Active contactless card(Type A,B,Mifare)
  317. // The first,second,third activation order decided by fstType,scdType,thdType respectively
  318. // fstType,scdType,thdType can be one of 'A','B','M','0'(30H,no type)
  319. // outType indicates the type of activation result
  320. //
  321. ErrorCodeEnum ContactlessCardImpl::ActiveContactlessICCard(char fstType, char scdType, char thdType, char &outType)
  322. {
  323. LOG4VTM(WARN, "<Contactless::ActiveContactlessICCard> - "
  324. << "Enter-");
  325. int iRet = Error_Succeed;
  326. try
  327. {
  328. if (!bDrvFlag)
  329. {
  330. LOG4VTM(WARN, "<Contactless::ActiveContactlessICCard> - "
  331. << "依赖库加载失败");
  332. iRet = Error_NotInit;
  333. throw iRet;
  334. }
  335. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  336. if (!bDevOpen)
  337. {
  338. sprintf(m_ErrInfo.szErrMsg, "Device Not Connected.");
  339. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  340. LOG4VTM(WARN, "<Contactless::ActiveContactlessICCard> - "
  341. << "设备未连接");
  342. iRet = Error_DevConnFailed;
  343. throw iRet;
  344. }
  345. if (fstType == 'A')
  346. {
  347. drv_CardReader->SetCardType(0x08);
  348. char sAtr[1024] = "\0";
  349. int iAtr = 0;
  350. iRet = drv_CardReader->ICCPower(3, sAtr, &iAtr);
  351. if (iRet != Error_Succeed)
  352. {
  353. sprintf(m_ErrInfo.szErrMsg, "Hardware Error.");
  354. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  355. LOG4VTM(WARN, "<Contactless::ActiveContactlessICCard> - "
  356. << "执行ICCPower失败返回" << iRet);
  357. iRet = Error_Hardware;
  358. throw iRet;
  359. }
  360. outType = 'A';
  361. }
  362. }
  363. catch (int ierror)
  364. {
  365. iRet = ierror;
  366. }
  367. LOG4VTM(WARN, "<Contactless::ActiveContactlessICCard> - "
  368. << "Exit-");
  369. return (ErrorCodeEnum)iRet;
  370. }
  371. //
  372. // Deactivate contactless IC card
  373. //
  374. ErrorCodeEnum ContactlessCardImpl::DeactContactlessICCard()
  375. {
  376. LOG4VTM(WARN, "<Contactless::DeactContactlessICCard> - "
  377. << "Enter-");
  378. int iRet = Error_Succeed;
  379. try
  380. {
  381. if (!bDrvFlag)
  382. {
  383. LOG4VTM(WARN, "<Contactless::DeactContactlessICCard> - "
  384. << "依赖库加载失败");
  385. iRet = Error_NotInit;
  386. throw iRet;
  387. }
  388. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  389. if (!bDevOpen)
  390. {
  391. sprintf(m_ErrInfo.szErrMsg, "Device Not Connected.");
  392. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  393. LOG4VTM(WARN, "<Contactless::DeactContactlessICCard> - "
  394. << "设备未连接");
  395. iRet = Error_DevConnFailed;
  396. throw iRet;
  397. }
  398. drv_CardReader->SetCardType(0x08);
  399. iRet = drv_CardReader->ICCPower(0x0C, NULL, NULL);
  400. if (iRet != Error_Succeed)
  401. {
  402. sprintf(m_ErrInfo.szErrMsg, "Hardware Error.");
  403. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  404. LOG4VTM(WARN, "<Contactless::DeactContactlessICCard> - "
  405. << "执行ICCPower失败返回" << iRet);
  406. iRet = Error_Hardware;
  407. throw iRet;
  408. }
  409. }
  410. catch (int ierror)
  411. {
  412. iRet = ierror;
  413. }
  414. LOG4VTM(WARN, "<Contactless::DeactContactlessICCard> - "
  415. << "Exit-");
  416. return (ErrorCodeEnum)iRet;
  417. }
  418. //
  419. // Warm reset card(IC)
  420. //
  421. ErrorCodeEnum ContactlessCardImpl::WarmReset()
  422. {
  423. LOG4VTM(WARN, "<Contactless::WarmReset> - "
  424. << "Enter-");
  425. int iRet = Error_Succeed;
  426. try
  427. {
  428. if (!bDrvFlag)
  429. {
  430. LOG4VTM(WARN, "<Contactless::WarmReset> - "
  431. << "依赖库加载失败");
  432. iRet = Error_NotInit;
  433. throw iRet;
  434. }
  435. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  436. if (!bDevOpen)
  437. {
  438. sprintf(m_ErrInfo.szErrMsg, "Device Not Connected.");
  439. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  440. LOG4VTM(WARN, "<Contactless::WarmReset> - "
  441. << "设备未连接");
  442. iRet = Error_DevConnFailed;
  443. throw iRet;
  444. }
  445. drv_CardReader->SetCardType(0x08);
  446. iRet = drv_CardReader->ICCPower(0x0C, NULL, NULL);
  447. char sAtr[1024] = "\0";
  448. int iAtr = 0;
  449. iRet = drv_CardReader->ICCPower(3, sAtr, &iAtr);
  450. if (iRet != Error_Succeed)
  451. {
  452. sprintf(m_ErrInfo.szErrMsg, "Hardware Error.");
  453. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  454. LOG4VTM(WARN, "<Contactless::WarmReset> - "
  455. << "执行ICCPower失败返回" << iRet);
  456. iRet = Error_Hardware;
  457. throw iRet;
  458. }
  459. }
  460. catch (int ierror)
  461. {
  462. iRet = ierror;
  463. }
  464. LOG4VTM(WARN, "<Contactless::WarmReset> - "
  465. << "Exit-");
  466. return (ErrorCodeEnum)iRet;
  467. }
  468. //
  469. // Mifare operation
  470. // Arguments:
  471. // - eFunType:function type as load key,authentication and so on
  472. // - return/data(hex) byte order like BIG EDIAN. ex:0x12345678 --> data[i] = 0x12,data[i+1] = 0x34,data[i+2] = 0x56,data[i+3] = 0x78
  473. // - sendBuf:[parameter(hex)][data(hex)]
  474. // - recvBuf:[status(1byte)][return data(hex)]
  475. // -- [eFunType],[parameter,data],[status(1byte),return data]
  476. // -- [CI_MIFARE_LOAD_KEY],[key select(1byte),sector num(1byte),uncoded keys(6bytes)],[status(1byte)]
  477. // -- [CI_MIFARE_AUTH],[key select(1byte),sector num(1byte)],[status(1byte)]
  478. // -- [CI_MIFARE_READ],[block num(1byte)],[status(1byte),data(16bytes)]
  479. // -- [CI_MIFARE_WRITE],[block num(1byte),data(16bytes)],[status(1byte)]
  480. // -- [CI_MIFARE_INC],[source block num(1byte),destination block num(1byte),inc value(4bytes)],[status(1byte)]
  481. // -- [CI_MIFARE_DEC],[source block num(1byte),destination block num(1byte),dec value(4bytes)],[status(1byte)]
  482. // -- key select(1byte):AKey(00h),BKey(01h)
  483. // -- status(1byte):OK(00h),other error code(!00h)
  484. ErrorCodeEnum ContactlessCardImpl::MifareCommand(MifareFuctionEnum eFunType, CmdInfo sendBuf, CmdInfo &recvBuf)
  485. {
  486. LOG4VTM(WARN, "<Contactless::MifareCommand> - "
  487. << "Enter-");
  488. int iRet = Error_Succeed;
  489. LOG4VTM(WARN, "<Contactless::MifareCommand> - "
  490. << "Exit-");
  491. return (ErrorCodeEnum)iRet;
  492. }
  493. //
  494. // RF Type A,B command.
  495. // APDU:Application Protocol Data Unit
  496. // Arguments:
  497. // - CmdSend.lpCmd:Command-APDU
  498. // - CmdRecv.lpData:Response-APDU
  499. //
  500. ErrorCodeEnum ContactlessCardImpl::RFTypeABCommand(CmdInfo sendBuf, CmdInfo &recvBuf)
  501. {
  502. LOG4VTM(WARN, "<Contactless::RFTypeABCommand> - "
  503. << "Enter-");
  504. int iRet = Error_Succeed;
  505. try
  506. {
  507. if (!bDrvFlag)
  508. {
  509. LOG4VTM(WARN, "<Contactless::RFTypeABCommand> - "
  510. << "依赖库加载失败");
  511. iRet = Error_NotInit;
  512. throw iRet;
  513. }
  514. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  515. if (!bDevOpen)
  516. {
  517. sprintf(m_ErrInfo.szErrMsg, "Device Not Connected.");
  518. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  519. LOG4VTM(WARN, "<Contactless::RFTypeABCommand> - "
  520. << "设备未连接");
  521. iRet = Error_DevConnFailed;
  522. throw iRet;
  523. }
  524. drv_CardReader->SetCardType(0x08);
  525. unsigned char szSendData[1024] = "";
  526. memset(szSendData, 0, sizeof(szSendData));
  527. int iSendLength = 0;
  528. memcpy(szSendData, sendBuf.data, sendBuf.dwSize);
  529. iSendLength = sendBuf.dwSize;
  530. unsigned char szRecvData[1024] = "";
  531. int iRecvLength = 0;
  532. TRANSMIT:
  533. memset(szRecvData, 0, sizeof(szRecvData));
  534. iRet = drv_CardReader->ICCTransmit(0, (char *)szSendData, iSendLength, (char *)szRecvData, &iRecvLength);
  535. if (iRet != Error_Succeed)
  536. {
  537. sprintf(m_ErrInfo.szErrMsg, "Hardware Error.");
  538. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  539. LOG4VTM(WARN, "<Contactless::RFTypeABCommand> - "
  540. << "执行ICCTransmit失败返回" << iRet);
  541. iRet = Error_Hardware;
  542. throw iRet;
  543. }
  544. if (szRecvData[iRecvLength - 2] == 0x61)
  545. {
  546. memset(szSendData, 0, sizeof(szSendData));
  547. szSendData[0] = 0x00;
  548. szSendData[1] = 0xC0;
  549. szSendData[2] = 0x00;
  550. szSendData[3] = 0x00;
  551. szSendData[4] = szRecvData[iRecvLength - 1];
  552. iSendLength = 5;
  553. goto TRANSMIT;
  554. }
  555. else if (szRecvData[iRecvLength - 2] == 0x6C)
  556. {
  557. szSendData[iSendLength - 1] = szRecvData[iRecvLength - 1];
  558. goto TRANSMIT;
  559. }
  560. memcpy(recvBuf.data, szRecvData, iRecvLength);
  561. recvBuf.dwSize = iRecvLength;
  562. }
  563. catch (int ierror)
  564. {
  565. iRet = ierror;
  566. }
  567. LOG4VTM(WARN, "<Contactless::RFTypeABCommand> - "
  568. << "Exit-");
  569. return (ErrorCodeEnum)iRet;
  570. }
  571. //halt card
  572. //card have been halted must move from induction zone then can be found again
  573. ErrorCodeEnum ContactlessCardImpl::HaltCard()
  574. {
  575. LOG4VTM(WARN, "<Contactless::HaltCard> - "
  576. << "Enter-");
  577. int iRet = Error_Succeed;
  578. try
  579. {
  580. if (!bDrvFlag)
  581. {
  582. LOG4VTM(WARN, "<Contactless::HaltCard> - "
  583. << "依赖库加载失败");
  584. iRet = Error_NotInit;
  585. throw iRet;
  586. }
  587. memset(m_ErrInfo.szErrMsg, 0, sizeof(m_ErrInfo.szErrMsg));
  588. if (!bDevOpen)
  589. {
  590. sprintf(m_ErrInfo.szErrMsg, "Device Not Connected.");
  591. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  592. LOG4VTM(WARN, "<Contactless::HaltCard> - "
  593. << "设备未连接");
  594. iRet = Error_DevConnFailed;
  595. throw iRet;
  596. }
  597. drv_CardReader->SetCardType(0x08);
  598. iRet = drv_CardReader->ICCPower(0x0C, NULL, NULL);
  599. if (iRet != Error_Succeed)
  600. {
  601. sprintf(m_ErrInfo.szErrMsg, "Hardware Error.");
  602. m_ErrInfo.dwErrMsgLen = strlen(m_ErrInfo.szErrMsg);
  603. LOG4VTM(WARN, "<Contactless::HaltCard> - "
  604. << "执行ICCPower失败返回" << iRet);
  605. iRet = Error_Hardware;
  606. throw iRet;
  607. }
  608. }
  609. catch (int ierror)
  610. {
  611. iRet = ierror;
  612. }
  613. LOG4VTM(WARN, "<Contactless::HaltCard> - "
  614. << "Exit-");
  615. return (ErrorCodeEnum)iRet;
  616. }