服务热线13822218564
身份证阅读器

技术服务

普天CP IDMR02/TG Linux二次开发包SDK(含身份证相片解码)

来源:www.xinzhongxin.net 标签:Linux 普天CPIDMR02/TG 相片解码  发布时间:2018-10-23 11:43:47

东信身份证阅读器模组模块,支持身份证、社保卡、CPU卡、M1卡、IC卡、医保卡、磁条卡、银行卡等多种卡片识别读取,提供完善的接口SDK二次开发技术支持,可提供Linux、单片机、ARM的通讯协议以及Android、Windows等系统二次开发包,可以适用于市场上的闸机、门禁、人脸识别考勤机、机器人终端、通道闸等产品使用。

身份证阅读器Linux系统开发包

版本:V2018.09.25

注意:此Linux版本是我公司最新的采用USB接口通讯的开发包,涵盖了身份证、M1、CPU、IC等多种卡片的Linux系统应用示例,包括了身份证相片解码。

应用产品:门禁系统、道闸、考勤系统以及人脸识别系统、自助终端、机器人系统等。

适合本Linux二次开发的身份证阅读器系列产品

///////////////////////////////////////////各卡片操作顺序//////////////////////////////

【typeA CPU 卡操作顺序】

1 设置为TypeA卡片

2 请求卡片

3 防碰撞

4 选择卡片

5 上电

6 APDU 命令

【typeB 卡操作顺序】

1 设置为TypeB卡片

2 上电

3 选卡

4 APDU 命令

【M1卡操作顺序】

1 请求卡片

2 防碰撞

3 选择卡片

4 认证密钥

5 读或写

【接触CPU卡操作顺序】

1 上电复位

2 APDU 命令

【身份证操作顺序】

读取证件

获取证件类型

获取信息

Linux系统开发包核心代码:

#ifndef _EST100_BASE_H_

#define _EST100_BASE_H_

#include <stdio.h>

#include <errno.h>

#include <dlfcn.h>

#include <errno.h>

#include <unistd.h>

#include <stdlib.h>    

#include <stdarg.h>

#include <unistd.h>     

#include <sys/time.h>

#include <ctype.h>

#include <sys/ioctl.h>

#include <fcntl.h>

#include <string.h>

#include <sys/types.h>

#include <stddef.h>   

#include <termios.h> 

#include <strings.h>

#include <stdbool.h>

#include <locale.h>

#include <iconv.h>

#include <sys/io.h>//chmod

#include <sys/stat.h>

#include "./include/libusb-1.0/libusb.h" 

#define IFD_OK0 //执行成功

#define IFD_ICC_TypeError-1 //卡片类型不对

#define IFD_ICC_NoExist-2 //无卡

#define IFD_ICC_NoPower-3 //有卡未上电

#define IFD_ICC_NoResponse-4     //卡片无应答

#define IFD_ConnectError-11     //读卡器连接错

#define IFD_UnConnected-12         //未建立连接(没有执行打开设备函数)

#define IFD_BadCommand-13         //(动态库)不支持该命令

#define IFD_ParameterError-14     //(发给动态库的)命令参数错

#define IFD_CheckSumError-15     //信息校验和出错

#define IFD_OutTime   -20

#ifdef __cplusplus

extern "C" {

#endif

/******************************************************************************************************************************************\

\   /

/设备类   \

\   /

\******************************************************************************************************************************************/


/*****************************************

* 功能:连接读卡器 

* 参数: 

*dev_name:[IN] 端口号,固定"USB1"  

* 返回值: 

*返回大于0的设备句柄 

******************************************/

long ICC_Reader_Open(char * dev_name);

/*****************************************

* 功能:断开读卡器连接

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

* 返回值: 

*成功返回0

***************************************************************/

long ICC_Reader_Close(long ReaderHandle);

/*****************************************

* 功能: 蜂鸣 

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*timeout: [IN] 超时时间,固定为5

* 返回值: 

*成功返回0 

******************************************/

long ICC_PosBeep(long ReaderHandle, unsigned char timeOut);

/******************************************************************************************************************************************\

\   /

/接CPU   \

\   /

\******************************************************************************************************************************************/

/*****************************************

* 功能: 接触CPU卡上电(冷复位)

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*ICC_Slot_No:[IN] 卡座号 0x01(大卡座),0x11~0x14(SAM1~SAM4)

*Response:[OUT] ATR

* 返回值: 

*成功返回数据长度

***************************************************************/

long ICC_Reader_pre_PowerOn(long ReaderHandle, unsigned char ICC_Slot_No, unsigned char* Response);

/*****************************************

* 功能: 接触CPU卡下电

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*ICC_Slot_No:[IN] 卡座号 0x01(大卡座),0x11~0x14(SAM1~SAM4)

* 返回值: 

*成功返回0

***************************************************************/

long ICC_Reader_PowerOff(long ReaderHandle,unsigned char ICC_Slot_No);

/*****************************************

* 功能: 接触CPU卡执行APDU命令

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*ICC_Slot_No:[IN] 卡座号 0x01(大卡座),0x11~0x14(SAM1~SAM4)

*Lenth_of_Command_APDU: [IN] APDU命令的长度

*Command_APDU:[IN] APDU命令

*Response_APDU: [OUT] 响应信息

* 返回值: 

*成功返回响应信息数据的长度

***************************************************************/

long ICC_Reader_Application(long ReaderHandle,unsigned char ICC_Slot_No, long Lenth_of_Command_APDU,unsigned char* Command_APDU,unsigned char* Response_APDU);  //执行apdu命令  返回数据长

/******************************************************************************************************************************************\

\   /

/非接类   \

\   /

\******************************************************************************************************************************************/

/****************************************

* 功能: 设置为操作TypeA卡

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

* 返回值: 

*成功返回0

***************************************************************/

long PICC_Reader_SetTypeA(long ReaderHandle);

/*****************************************

* 功能: 设置为操作TypeB卡

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

* 返回值: 

*成功返回0

***************************************************************/

long PICC_Reader_SetTypeB(long ReaderHandle);

/*****************************************

* 功能: 请求卡片

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

* 返回值: 

*成功返回0

***************************************************************/

long PICC_Reader_Request(long ReaderHandle);

/*****************************************

* 功能: 防碰撞

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*UID: [OUT] 4字节UID

* 返回值: 

*成功返回0

***************************************************************/

long PICC_Reader_anticoll(long ReaderHandle,unsigned char *uid);

/*****************************************

* 功能: 选择卡片

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*cardtype:[IN] 0x41表示TypeA & M1, 0x42表示TypeB

* 返回值: 

*成功返回0

***************************************************************/

long PICC_Reader_Select(long ReaderHandle,unsigned char cardtype);

/*****************************************

* 功能: TypeA卡上电

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*Response: [OUT] 上电返回数据

* 返回值: 

*成功返回数据长度

***************************************************************/

long PICC_Reader_PowerOnTypeA(long ReaderHandle,unsigned char* Response);

/*****************************************

* 功能: TypeB卡上电

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*Response: [OUT] 上电返回数据

* 返回值: 

*成功返回数据长度

***************************************************************/

long PICC_Reader_PowerOnTypeB(long ReaderHandle,unsigned char* Response);

/*****************************************

* 功能: TypeA & B 卡执行APDU命令

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*Lenth_of_Command_APDU: [IN] APDU命令的长度

*Command_APDU:[IN] APDU命令

*Response_APDU: [OUT] 响应信息

* 返回值: 

*成功返回响应信息数据的长度

***************************************************************/

long PICC_Reader_Application(long ReaderHandle,long Lenth_of_Command_APDU,unsigned char* Command_APDU,unsigned char* Response_APDU);

/*****************************************

* 功能: M1卡认证秘钥

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*Mode: [IN] 0x60 表示认证KeyA, 0x61表示认证KeyB

*SecNr:[IN] 扇区号 S50系列卡 0~15, S70系列卡 0~63

*Key: [IN] 6字节秘钥

* 返回值: 

*成功返回0

***************************************************************/

long PICC_Reader_Authentication_Pass(long ReaderHandle,unsigned char Mode, unsigned char SecNr,unsigned char *PassWord);

/*****************************************

* 功能: M1读卡

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*Addr:[IN] 块地址 S50系列卡 0~63, S70系列卡 0~255, 例如:1扇区1块,这里Addr=5=1*4 + 1(扇区号*4 + 块号)

*Data:[OUT] 16字节块数据

* 返回值: 

*成功返回0

*****************************************************************************************************************/

long PICC_Reader_Read(long ReaderHandle,unsigned char Addr,unsigned char *Data);

/*****************************************

* 功能: M1写卡

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*Addr:[IN] 块地址 S50系列卡 0~63, S70系列卡 0~255, 例如:1扇区1块,这里Addr=5=1*4 + 1(扇区号*4 + 块号)

*Data: [IN] 16字节待写入数据

* 返回值: 

*成功返回0

***************************************************************************************************************/

long PICC_Reader_Write(long ReaderHandle,unsigned char Addr,unsigned char *Data);

/******************************************************************************************************************************************\

\   /

/磁条卡   \

\   /

\******************************************************************************************************************************************/

/*****************************************

* 功能: 读磁条卡

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

*ctime:[IN] 等待刷卡的超时时间,单位:秒

*track:[IN] 磁道 1~3

*rlen: [OUT] 返回的磁道数据长度

*Data: [OUT] 返回的磁道数据

* 返回值: 

*成功返回0

****************************************************************/

long Rcard(long ReaderHandle,unsigned char ctime,int track,unsigned char *rlen,char *Data);

long ICC_GetTimeOut(long ReaderHandle, unsigned char flag);//内部调用

/******************************************************************************************************************************************\

\   /

/身份证   \

\   /

\******************************************************************************************************************************************/

/*****************************************

* 功能: 读取证件(居民身份证 + 外国人永久居留证 + 港澳台居民居住证)

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

* 返回值: 

*成功返回0,执行成功后可调用下列get函数获取相应的信息

***********************************************************************/

long PICC_ReadIDCard(long ReaderHandle);

/*****************************************

* 功能: 读取证件,包含指纹(居民身份证 + 外国人永久居留证 + 港澳台居民居住证)

* 参数: 

*ReaderHandle:[IN] 执行ICC_Reader_Open 函数成功时的返回值

* 返回值: 

*成功返回0,执行成功后可调用下列get函数获取相应的信息

***********************************************************************/

long PICC_ReadIDCardFP(long ReaderHandle);

/*****************************************

* 功能: 获取证件类型

* 参数: 

*

* 返回值: 

*0:表示居民身份证

*1:表示外国人永久居留证

*2:表示港澳台居民居住证

*****************************************/

int GetCardType();

/*****************************************

* 功能: 获取姓名

* 参数: 

*pName: [OUT] 姓名

* 返回值: 

*成功返回0

* 包含证件类型:0、1、2

*****************************************/

int GetName(char* pName);

/*****************************************

* 功能: 获取性别

* 参数: 

*pSex: [OUT] 性别

* 返回值: 

*成功返回0

* 包含证件类型:0、1、2

*****************************************/

int GetSex(char* pSex);

/*****************************************

* 功能: 获取民族

* 参数: 

*pNation: [OUT] 民族

* 返回值: 

*成功返回0

* 包含证件类型:0

*****************************************/

int GetNation(char* pNation);

/*****************************************

* 功能: 获取出生日期

* 参数: 

*pBirth: [OUT] 出生日期

* 返回值: 

*成功返回0

* 包含证件类型:0、1、2

*****************************************/

int GetBirth(char* pBirth);

/*****************************************

* 功能: 获取住址

* 参数: 

*pAddress: [OUT] 住址

* 返回值: 

*成功返回0

* 包含证件类型:0、2

*****************************************/

int GetAddress(char* pAddress);

/*****************************************

* 功能: 获取证件号码

* 参数: 

*pCertNo: [OUT] 证件号码

* 返回值: 

*成功返回0

* 包含证件类型:0、1、2

*****************************************/

int GetCertNo(char* pCertNo);

/*****************************************

* 功能: 获取签发机关

* 参数: 

*pDepartemt: [OUT] 签发机关

* 返回值: 

*成功返回0

* 包含证件类型:0、2

*****************************************/

int GetDepartemt(char* pDepartemt);

/*****************************************

* 功能: 获取有效起始日期

* 参数: 

*pEffectDate: [OUT] 有效起始日期

* 返回值: 

*成功返回0

* 包含证件类型:0、1、2

*****************************************/

int GetEffectDate(char* pEffectDate);

/*****************************************

* 功能: 获取有效截止日期

* 参数: 

*pExpireDate: [OUT] 有效截止日期

* 返回值: 

*成功返回0

* 包含证件类型:0、1、2

*****************************************/

int GetExpireDate(char* pExpireDate);

/*****************************************

* 功能: 获取通行证号码

* 参数: 

*pTXZHM: [OUT] 通行证号码

* 返回值: 

*成功返回0

* 包含证件类型:2

*****************************************/

int GetTXZHM(char* pTXZHM);

/*****************************************

* 功能: 获取通行证签发次数

* 参数: 

*pTXZQFCS: [OUT] 通行证签发次数

* 返回值: 

*成功返回0

* 包含证件类型:2

*****************************************/

int GetTXZQFCS(char* pTXZQFCS);

/*****************************************

* 功能: 获取英文名

* 参数: 

*pEnName: [OUT] 外国人英文名

* 返回值: 

*成功返回0

* 包含证件类型:1

*****************************************/

int GetEnName(char* pEnName);

/*****************************************

* 功能: 获取国籍代码

* 参数: 

*pNationalityCode: [OUT] 外国人国籍代码

* 返回值: 

*成功返回0

* 包含证件类型:1

*****************************************/

int GetNationalityCode(char* pNationalityCode);

/*****************************************

* 功能: 获取证件版本

* 参数: 

*pCardVersion: [OUT] 外国人居留证证件版本

* 返回值: 

*成功返回0

* 包含证件类型:1

*****************************************/

int GetCardVersion(char* pCardVersion);

/*****************************************

* 功能: 获取照片

* 参数: 

*dlpath: [IN] so路径, 例如:"../lib/libwltdecode.so"

*pBmpfilepath: [IN] 照片路径, 例如:"../list/zp.bmp"

* 返回值: 

*成功返回0

* 包含证件类型:0、1、2

*****************************************/

int GetBmpFile(const char* dlpath, char* pBmpfilepath);

/*****************************************

* 功能: 是否含指纹信息

* 参数: 

*

* 返回值: 

*成功返回指纹数据长度,0表示没有

* 包含证件类型:0、1、2

*****************************************/

int IsFingerExist();

/*****************************************

* 功能: 获取指纹信息

* 参数: 

*fpInfo: [OUT] 指纹数据

* 返回值: 

*成功返回获取到的指纹数据长度,0表示没有

* 包含证件类型:0、1、2

*****************************************/

int GetFingerprint(unsigned char* fpInfo);

#ifdef __cplusplus

}

#endif

#endif


产品咨询热线:13822218564

技术咨询热线:13539883002

广东东信智能科技有限公司 www.eastcoms.com

广东省广州市科学城总部经济区观虹路12号


推荐有礼!

栏目列表

联系我们


  身份证阅读器批发中心
  销售热线:13822218564
  技术支持:020-29805619
二维码
服务热线13822218564
 
QQ在线咨询