private
static UInt16 InitializePort = 0x0101;
//初始化波特率
private static UInt16 SetDeviceNodeNumber = 0x0102; //发设备号
private static UInt16 ReadDeviceNodeNumber = 0x0103; //读设备号
private static UInt16 ReadDeviceMode = 0x0104; //读读卡器型号
private static UInt16 SetBuzzerBeep = 0x0106; //蜂鸣
private static UInt16 SetLedColor = 0x0107; //设置红绿灯
private static UInt16 SetReaderWorkingStatus = 0x0108; //保留
private static UInt16 SetAntennaStatus = 0x010c; //设置天线状态
private static UInt16 MifareRequest = 0x0201; //请求卡的类型
private static UInt16 MifareAnticollision = 0x0202; //读卡号
private static UInt16 MifareSelect = 0x0203; //确认卡号
private static UInt16 MifareHlta = 0x0204; //停机应答
private static UInt16 MifareAuthentication1 = 0x0206; //卡片鉴定
private static UInt16 MifareAuthentication2 = 0x0207; //输入密码
private static UInt16 MifareRead = 0x0208; //读卡
private static UInt16 MifareWrite = 0x0209; //写卡
private static UInt16 MifareInitval = 0x020A; //初始化钱包
private static UInt16 MifareReadBalance = 0x020B;
private static UInt16 MifareDecrement = 0x020C; //减值
private static UInt16 MifareIncrement = 0x020D; //加值
private static UInt16 MifareRestore = 0x020E; //从一个块到缓存
private static UInt16 MifareTransfer = 0x020F; //从缓存到一个块
private static UInt16 MifareUltraLightAnticoll = 0x0212;
private static UInt16 MifareUltraLightWrite = 0x0213;
private static UInt16 SetDeviceNodeNumber = 0x0102; //发设备号
private static UInt16 ReadDeviceNodeNumber = 0x0103; //读设备号
private static UInt16 ReadDeviceMode = 0x0104; //读读卡器型号
private static UInt16 SetBuzzerBeep = 0x0106; //蜂鸣
private static UInt16 SetLedColor = 0x0107; //设置红绿灯
private static UInt16 SetReaderWorkingStatus = 0x0108; //保留
private static UInt16 SetAntennaStatus = 0x010c; //设置天线状态
private static UInt16 MifareRequest = 0x0201; //请求卡的类型
private static UInt16 MifareAnticollision = 0x0202; //读卡号
private static UInt16 MifareSelect = 0x0203; //确认卡号
private static UInt16 MifareHlta = 0x0204; //停机应答
private static UInt16 MifareAuthentication1 = 0x0206; //卡片鉴定
private static UInt16 MifareAuthentication2 = 0x0207; //输入密码
private static UInt16 MifareRead = 0x0208; //读卡
private static UInt16 MifareWrite = 0x0209; //写卡
private static UInt16 MifareInitval = 0x020A; //初始化钱包
private static UInt16 MifareReadBalance = 0x020B;
private static UInt16 MifareDecrement = 0x020C; //减值
private static UInt16 MifareIncrement = 0x020D; //加值
private static UInt16 MifareRestore = 0x020E; //从一个块到缓存
private static UInt16 MifareTransfer = 0x020F; //从缓存到一个块
private static UInt16 MifareUltraLightAnticoll = 0x0212;
private static UInt16 MifareUltraLightWrite = 0x0213;
RFID射频识别是一种非接触式的自动识别技术,它通过射频信号自动识别目标对象并获取相关数据,识别工作无须人工干预,可工作于各种恶劣环境。RFID技术可识别高速运动物体并可同时识别多个标签,操作快捷方便。 RFID是一种简单的无线系统,只有两个基本器件,该系统用于控制、检测和跟踪物体。系统由一个询问器(或阅读器)和很多应答器(或标签)组成。(详情请参见百度百科《RFID》)
对RFID产品提供者来说,设计开发并全盘掌握RFID技术是不大可能的,因为一条完整的RFID产业链包括标准、芯片、天线、标签封装、读写设备、中间件、应用软件、系统集成等,其中最关键的技术是芯片的设计与制造。通用芯片的设计和制造技术掌握在国外飞利浦(Phillips)、德州仪器(TI)、Amtech公司等公司。
对我们一般开发用户来说,其实主要就是通过串口(即使物理接口是USB,最终大都转换为串口操作)来操作阅读器,对附近的RFID标签进行读取,提取ID号,并读写EEROM扇区上的数据。
由于RFID标签内嵌CPU单元,采用应答方式和阅读器通信,所以RFID标签就会相对容易地保护EEROM扇区上的数据不被非法读写,合法读取的阅读器必须提供指定的KEY才可以读写指定扇区上的数据(不过我有一个担心,如果某种技术单单可以提取出EEROM模块,直接对其扇区上的数据进行读取,那将绕过这个保护机制,所以还是建议写在EEROM扇区上的数据也要进行加密。我想实际的RFID标签应该是把加密后的数据写入到EEROM扇区,而不是直接写入操作者提供的明文数据。不过这种机制似乎无法避免自己的卡被复制)。
RFID卡或标签根据应用领域的不同,根据相关的国际标准来生产不同规格的产品。我手头上的RFID卡(MF1ICS50)符合ISO14443A协议标准,EEROM的容量为1024字节,分16个分区,每区64个字节,这个64个字节又分为4块,其中最后一块存放KEY-A,KEY-B及访问策略,所以有效数据区的大小为768个字节。
针对windows平台,生产读卡器的厂家一般会提供自己的SDK,用户不需要熟悉通信协议,自行开发串口通信程序,直接调用其DLL库提供的API接口函数即可。有些厂家甚至提供了VB、VC、C#等调用示例。
不过对于.Net Micro Framework的用户来说就没有这么幸运,必须根据厂家提供的通信协议(读写的RFID卡虽然相同,但是不同厂家的阅读器的串口通信协议却各有千秋)。
无论哪个厂家生产的阅读器,其读卡操作一般都要有如下几个过程:
第一步:获取RFID卡的类型;
第二步:读取RFID卡的卡号;
第三步:选择指定卡号的RFID卡;
第四步:设置指定扇区的KEY的类型,及具体的KEY值;
第五步:读写指定扇区的数据;
第六步:使选择的RFID卡进入休眠状态。
根据厂家提供的协议,我已实现完整的RFID阅读器操作类,具体操作命令如下:
读卡器测试程序执行后的效果图如下:
引申阅读:《.Net Micro Framework 快速入门》
本文转自yefanqiu51CTO博客,原文链接:http://blog.51cto.com/yfsoft/321205
,如需转载请自行联系原作者