RFID技术在.Net Micro Framework中的应用

标签: .net加密制造工作中间件产品
3677人阅读 评论(3) 收藏 举报
分类:

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-AKEY-B及访问策略,所以有效数据区的大小为768个字节。

针对windows平台,生产读卡器的厂家一般会提供自己的SDK,用户不需要熟悉通信协议,自行开发串口通信程序,直接调用其DLL库提供的API接口函数即可。有些厂家甚至提供了VBVCC#等调用示例。

不过对于.Net Micro Framework的用户来说就没有这么幸运,必须根据厂家提供的通信协议(读写的RFID卡虽然相同,但是不同厂家的阅读器的串口通信协议却各有千秋)。

无论哪个厂家生产的阅读器,其读卡操作一般都要有如下几个过程:

第一步:获取RFID卡的类型;

第二步:读取RFID卡的卡号;

第三步:选择指定卡号的RFID卡;

第四步:设置指定扇区的KEY的类型,及具体的KEY值;

第五步:读写指定扇区的数据;

第六步:使选择的RFID卡进入休眠状态。

根据厂家提供的协议,我已实现完整的RFID阅读器操作类,具体操作命令如下:

    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;

读卡器测试程序执行后的效果图如下:

引申阅读:《.Net Micro Framework 快速入门

 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:2609349次
    • 积分:30621
    • 等级:
    • 排名:第169名
    • 原创:390篇
    • 转载:7篇
    • 译文:0篇
    • 评论:2390条
    新浪微博
    博客专栏
    文章存档
    最新评论