RFID射频技术漫谈(1-5)

射频识别技术漫谈(1)——概念、分类


    现代社会智能卡已经渗透到生活的方方面面,公交卡、考勤卡、身份证、手机卡等等数不胜数。

智能卡按使用时是否和读卡器接触可分为接触式智能卡和非接触式智能卡,接触式智能卡上有6-8个触点,使用时插在卡座上,典型的如手机卡以及以前的公用电话卡。非接触式智能卡没有触点,卡上也没有电源,通过读卡器产生的电磁场获得能量并与读写器交换信息。由于非接触式智能卡的无源和免接触特性,卡的使用寿命和安全性大大提高,目前应用越来越广泛。


    根据安全等级,智能卡可分为存储器卡、逻辑加密卡和CPU卡。存储器卡就像一个无人看守且大门敞开的仓库,什么人都可以随便在卡中存取数据;逻辑加密卡则给仓库加了一把锁,只有有钥匙(密码)的人才能打开使用。CPU卡则如同安排了专人看守仓库,卡里面有CPU芯片,存储数据要验证口令,且可能不同的应用有不同口令,存取数据受到更加严格的控制,安全性最高。


    非接触式IC卡通过磁场从读写器获得能量并交换数据。这里的磁场通常称为射频场(Radio Frequency Field),所以这种卡片也通常称为射频卡,这种技术称为射频识别(Radio Frequency Identification,RFID)技术。不管叫什么名字,其实质都是一样的,都是无线电通讯,本质上与广播、电视、手机通讯并无区别。


    无线电通讯中很少有直接发射有用信号的,通常使用调制解调技术,将有用信号调制在某一频率的载波上,接收方收到调制信号后解调得到有用信号。非接触式IC卡的常用载波频率有125KHz、134.2KHz、13.56MHz、2.45GHz等,通常载波频率越高,数据的传送速率越高,技术上也较复杂。


    虽然都是免接触,不同卡的有效操作距离是不一样的。有些卡号称免接触,但读卡距离非常短,只有0-2厘米,这种卡被称为CICC卡(Close-CoupleICC),一般翻译成密耦合卡;有些卡的操作距离远一点,可以达到10厘米,这种卡被称为PICC卡(Proximity ICC),我们叫它接近卡;还有一种更远的,至少可以达到半米或更远,这种卡被称为VICC卡(Vicinity ICC),中文称疏耦合卡。


    业内还有一些不成文的习惯叫法。一般的卡片操作通常都是主从式,即读卡器作为主动方发送命令,卡片收到命令后作出反应,这种卡片我们称之为IC卡。有一类比较简单的卡,卡内只存储了一个识别号,通常只要进入射频场获得能量后就不停的主动发送这个识别号,这类卡习惯称ID卡。当然这些叫法只是习惯,事实上IC是集成电路的意思,以上卡片都应叫IC卡,不过习惯的力量往往是很大的,时间长了,大家也就接受这种称呼了。


    本人随后将就射频识别技术进行一系列的“漫谈”。所谓“漫谈”,非正规也。我写的既不是技术文档,更不是教材,只是本人十年来开发射频识别卡的一些点滴体会,用不太严谨的语言表达出来而已。另外由于我对125KHz,134.2KHz和13.56MHz比较熟悉,相关的射频卡都开发过,所以之后关于射频识别技术的叙述都是基于这3种频率。





射频识别技术漫谈(2)——国际标准

   如果你只是智能卡的用户,通常可以不必关注国际标准,但作为智能卡的专业开发人员,则至少也要对相关标准有所了解。国际标准一般都是西方人制定的,原版都是英文的,而所谓中文版往往是对原版的直译,许多情况下并未准确说出实际的意思,所以如果想看这些标准,还是看原版好。以下仅简单介绍比较重要的关于智能卡的国际标准。以后的叙述我可能很少提及这些标准,不读这些标准也不影响朋友们继续往下读,但是正所谓没有规矩,不成方圆,在这里只是告诉大家,之后的叙述都是基于这些国际标准的。


    一、ISO 7810:规定了识别卡的物理特性,比如卡的形状、尺寸等。


    二、ISO 7816:身份证集成电路卡国际标准。

这个标准包含的部分比较多,目前还在陆续发布与补充。7816是接触式IC卡必须遵循的国际标准,其中的有些部分也适用于非接触式智能卡。


    第一部分规定了接触式智能卡的物理特性;

    第二部分规定了接触式智能卡的触点尺寸与位置;

    第三部分规定了接触式智能卡的电信号和传输协议;

    第四部分规定了接触式智能卡与外界交互的接口组织、安全和命令;

    第五部分规定了接触式智能卡应用的命名方式与注册系统;

    第六部分规定了接触式智能卡与外界交互的数据元素;

    第七部分规定了接触式智能卡用于结构化查询语句的命令;

    第八部分规定了接触式智能卡安全操作命令;

    第九部分规定了接触式智能卡的卡管理命令;

    第十部分规定了同步卡的电信号和复位应答;

    第十一部分规定了使用生物统计法的个人认证;

    第十二部分规定了接触式智能卡USB电信号接口和操作时序;

    第十三部分规定了多应用环境下的应用管理命令;

    第十四部分好像没有;

    第十五部分规定了加密信息应用.修改件1:加密信息应用的实例。


    三、ISO 10536:密耦合卡(CICC)的国际标准。


    第一部分规定了CICC的物理特性;

    第二部分规定了CICC的耦合区域的尺寸和位置;

    第三部分规定了CICC的电信号和复位规程。


    四、ISO 14443:接近卡(PICC)的国际标准。


    第一部分规定了PICC的物理特性;

    第二部分规定了PICC的射频功率和信号接口;

    第三部分规定了PICC的的初始化和防冲突算法;

    第四部分规定了PICC的传输协议。


    五、ISO 15693:疏耦合卡(VICC)的国际标准。


    第一部分规定了VICC的物理特性;

    第二部分规定了VICC的空中接口和初始化;

    第三部分规定了VICC的防冲突和传输协议。


    六、ISO 11784/11785:动物识别编码的国际标准。


    11784规定了动物识别信号的编码结构;

    11785规定了动物识别的一些技术概念。


    七、ISO 10373:规定了识别卡的测试方法。


    这么多标准看了让人头都大了,其实作为一个RFID的开发和应用者来说,并不是所有这些协议都需要看的。首先如果你不造卡,物理部分就不用看了,厂家做出来什么样就是什么样;信号接口了解一下就行,因为每种卡片通常都有专用的接口芯片,除非从天线到CPU接口你自己全部用分立器件搭建,否则你应该花更多时间研究专用接口芯片的说明书;卡的通讯协议是我们最应该关注的,因为它需要开发人员在软件中实现;而动物识别编码的国际标准是做动物识别卡时用,它规定了卡片发送动物识别信息的编码规则,属于智能卡的应用范畴。


射频识别技术漫谈(3)——能量、调制


   无源和免接触是非接触式IC卡相对于接触式IC卡的两大特点。无源是指卡片上没有电源,免接触是指对卡片的读写操作不必和读写器接触。非接触式智能卡也是IC卡,而卡上的IC即集成电路工作时肯定是需要电源的,卡片自身没有电源而又不和读写器接触,那么电源从哪里来的呢?


    其实回答这个问题非常简单,那就是电磁感应。读写器产生一个电磁场,卡片上的天线是一个LC振荡电路,且这个振荡电路的共振频率和读写器电磁场的频率一致。当卡片进入读写器的射频场,卡上的振荡电路起振,电路振荡意味着有电子的流动,有电子的流动就可以用二极管让电子积累,电子的积累就会形成电压,有了电压智能卡就能工作了。卡片获得能量的方式大体就是这样,具体的实现方法,如果不打算自己做卡就没必要深究,只要懂得原理就可以了。如果还不明白,想想变压器吧,变压器的原边和副边也是绝缘的,但能量却可以从原边传递到副边,射频卡获得能量的方式就相当于变压器的副边。


    能量有了,那么读写器和卡片又是如何进行信息交流的呢?既然是免接触,那就只有通过无线电传输了。无线电传输很少有直接发送信号的,一般都是选定某一频率的载波,也就是正弦波,发送方把有用信号调制在载波上,接收方解调收到的信号,把载波去掉得到有用信号。无论电视、广播、手机通讯还是射频卡,其基于无线电通讯的原理都是一样的。


    载波(正弦波)有三要素,幅度、频率和相位,相应的有用信号对载波的调制也有三种:调幅、调频和调相。调幅是改变载波的幅度记录有用信号,调频是改变载波的频率记录有用信号,调相是改变载波的相位记录有用信号。调幅电路简单,容易受干扰,调频和调相结构复杂些,但抗干扰能力强,一个简单的例子是你的收音机FM(调频)比AM(调幅)声音好听的多。另外,调幅和调频要求载波频率远大于有用信号的最高频率,通常要10倍以上,而调相则无此要求,载波频率可以高于、等于(2BPSK)甚至低于(4BPSK,16BPSK)有用信号的频率。


    基于上述三种调制的特点,射频卡通讯距离最大不过几米,平常用的接近卡(PICC)最大距离才10公分,在这么短的距离范围内形成一个相对较强的局部射频场,几乎可以不用考虑干扰。射频卡上没有电源,尤其成本考虑,自然要求卡上电路越简单越好。所以,调幅虽然易受干扰但电路结构简单,成为射频卡调制的首选。


    调幅有一个指标叫调制系数,也就是衡量有用信号对载波幅度的调制有多大。调制系数为0,相当于没有调制,调制系数为1则相当于把载波的幅度调为0,一般调制系数都在0.1-0.9之间。显然由于射频卡需要从磁场中获得能量,如果调制系数接近1,意味着磁场关闭了,时间短了还行,时间长了卡上的电源必然会消失,卡片的基本工作条件都没有了,但调制系数大抗干扰能力强,容易解调。相反,调制系数小,卡片可以获得稳定的能量供应,但抗干扰能力弱,解调困难一些。


    在读写器与卡片的信息交流过程中,读写器产生射频场,向卡片发送数据时调制自己产生的射频场,这很好理解。但卡片是被动的,不仅不能产生射频场,还要从读写器的射频场中获取能量,那又如何通过调制射频场向读写器回送数据呢?射频识别技术中采用了一种叫做负载调制的方法。其原理也非常简单,还是以变压器为例,我们都有这样的常识,如果变压器的副边突然接入一个大的负载,变压器原边电压就会瞬间降低,切除负载,变压器的原边电压就会马上恢复。前面说了,射频卡相当于变压器的副边,卡内也有这样一个负载,接通负载时射频场的振荡幅度会减小,切除负载,射频场的幅度会恢复。卡片通过负载是否接入来表示发送的数据,读写器探测到射频场的幅度改变,就能知道卡片发送什么数据了。这就是卡片回送数据的原理。


射频识别技术漫谈(4)——数据编码


前已述及,射频识别技术中的调制方法一般使用调幅(AM),也就是将有用信号调制在载波的幅度上传送出去。这里的“有用信号”指用高低电平表示的数据“0”或“1”。那么如何用高低电平表示数据“0”或“1”呢?

最简单的办法就是用高电平表示“1”,用低电平表示“0”,这种代码叫全宽码,如下图所示:

    


这种编码方式存在的最大缺陷就是数据容易失步。上图的数据我们看的很清楚,但是想想如果发送方连续发送100个“0”或100个“1”,就会有100个单位的连续高电平或100个单位的连续低电平。这种情况下,接收方极有可能把数据的个数数错,把100数成99或101,这就是数据失步。所以这种编码很少直接采用。这就要求使用的编码既能让接收方知道发送方传送的是“1”还是“0”,又能让接收方正确分辨出每个二进制比特。实际的射频识别技术中采用的数据编码主要有以下几种,它们都能满足上述要求。


  1.曼侧斯特(Manchester)码

    如下图所示,曼侧斯特码每位数据的中心都有跳变,上升沿表示数据“1”,下降沿表示数据“0”,或者反之。当发送连续的“0”或“1”时,则在数据的开始部分增加一个状态转换沿。


 2.两相(Biphase)码

    两相码每位数据的开始处都有跳变,数据中心有跳变表示“1”,数据中心无跳变表示“0”,或者反之。


 3.频移键控(FSK)码

    频移键控码用不同的脉冲频率表示数据,脉冲频率高表示“1”,脉冲频率低表示“0”,或者反之。


  4.相移键控(FSK)码

    相移键控码用数据的开始处有没有相位翻转表示数据的变化,有相位的翻转表示数据发生了翻转(上一位如果是“0”,则当前发送“1”;上一位如果是“1”,则当前发送“0”),无相位的翻转表示数据没有发生变化(上一位如果是“0”,则当前发送“0”;上一位如果是“1”,则当前发送“1”),或者反之。


  5.米勒(Miller)码

     如图,米勒码用数据中心是否有跳变表示数据。数据中心有跳变表示“1”,数据中心无跳变表示“0”。当发送连续的“0”时,则在数据的开始处增加一个跳变防止失步。



  6.修正的米勒(Modified Miller)码

     修正的米勒码是ISO14443A规定使用的数据编码。数据中间有个窄脉冲表示“1”,数据中间没有窄脉冲表示“0”,当有连续的“0”时,从第二个“0”开始在数据的起始部分增加一个窄脉冲。该标准还规定起始位的开始处也有一个窄脉冲,而结束位用“0”表示。如果有两个连续的位开始和中间部分都没有窄脉冲,则表示无信息。


    7.副载波调制的曼侧斯特(Manchester)码

    副载波调制的曼侧斯特码也是ISO14443A规定使用的数据编码,在卡片向PCD回送数据时使用。副载波调制码元的右半部分表示数据“0”,副载波调制码元的左半部分表示数据“1”。



    射频识别技术中采用的编码方法还有许多种,有些是上述几种的变形。但无论采用什么编码方法,其原则都应该是数据利于传送和识别,且不能失步,有时候还要配合下面将要叙述的卡片防冲突。


射频识别技术漫谈(5)——防冲突

    正常情况下读写器某一时刻只能对磁场中的一张射频卡进行读写操作。但是当多张卡片同时进入读写器的射频场时,读写器怎么办呢?读写器需要选出唯一的一张卡片进行读写操作,这就是防冲突。


    防冲突机制是非接触式智能卡特有的问题。在接触式智能卡的操作中是不存在冲突的,因为接触式智能卡的读写器有一个专门的卡座,而且一个卡座只能插一张卡片,不存在读写器同时面对两张以上卡片的问题。常见的非接触式智能卡中的防冲突机制主要有以下几种:


    1.面向比特的防冲突机制。


    ISO14443A中使用这种防冲突机制,其原理是基于卡片有一个全球唯一的序列号。比如Mifare1卡,每张卡片有一个全球唯一的32位二进制序列号。显而易见,卡号的每一位上不是“1”就是“0”,而且由于是全世界唯一,所以任何两张卡片的序列号总有一位的值是不一样的,也就说总存在某一位,一张卡片上是“0”,而另一张卡片上是“1”。

    当两张以上卡片同时进入射频场,读写器向射频场发出卡呼叫命令,问射频场中有没有卡片。这些卡片同时回答“有卡片”;

    然后读写器发送防冲突命令“把你们的卡号告诉我”,收到命令后所有卡片同时回送自己的卡号。

    可能这些卡片卡号的前几位都是一样的。比如前四位都是1010,第五位上有一张卡片是“0”而其他卡片是“1”,于是所有卡片在一起说自己的第五位卡号的时候,由于有卡片说“0”,有卡片说“1”,读写器听出来发生了冲突。

    读写器检测到冲突后,对射频场中的卡片说,让卡号前四位是“1010”,第五位是“1”的卡片继续说自己的卡号,其他的卡片不要发言了。

    结果第五位是“1”的卡片继续发言,可能第五位是“1”的卡片不止一张,于是在这些卡片回送卡号的过程中又发生了冲突,读写器仍然用上面的办法让冲突位是“1”的卡片继续发言,其他卡片禁止发言,最终经过多次的防冲突循环,当只剩下一张卡片的时候,就没有冲突了,最后胜出的卡片把自己完整的卡号回送给读写器,读写器发出卡选择命令,这张卡片就被选中了,而其他卡片只有等待下次卡呼叫时才能再次参与防冲突过程。

    上述防冲突过程中,当冲突发生时,读写器总是选择冲突位为“1”的卡片胜出,当然也可以指定冲突位为“0”的卡片胜出。

    上述过程有点拟人化了,实际情况下读写器是怎么知道发生冲突了呢?在前面的数据编码中我们已经提到,卡片向读写器发送命令使用副载波调制的曼侧斯特(Manchester)码,副载波调制码元的右半部分表示数据“0”,副载波调制码元的左半部分表示数据“1”,当发生冲突时,由于同时有卡片回送“0”和“1”,导致整个码元都有副载波调制,读写器收到这样的码元,就知道发生冲突了。

    这种方法可以保证任何情况下都能选出一张卡片,即使把全世界同类型的所有卡片都拿来防冲突,最多经过32个防冲突循环就能选出一张卡片。缺点是由于卡序列号全世界唯一,而卡号的长度是固定的,所以某一类型的卡片的生产数量也是一定的,比如常见的Mifare1卡,由于只有4个字节的卡序列号,所以其生产数量最多为2的32次方,即4294967296张。


    2.面向时隙的防冲突机制


    ISO14443B中使用这种防冲突机制。这里的时隙(timeslot)其实就是个序号。这个序号的取值范围由读写器指定,可能的范围有1-1、1-2、1-4、1-8、1-16。当两张以上卡片同时进入射频场,读写器向射频场发出卡呼叫命令,命令中指定了时隙的范围,让卡片在这个指定的范围内随机选择一个数作为自己的临时识别号。然后读写器从1开始叫号,如果叫到某个号恰好只有一张卡片选择了这个号,则这张卡片被选中胜出。如果叫到的号没有卡片应答或者有多于一张卡片应答,则继续向下叫号。如果取值范围内的所有号都叫了一遍还没有选出一张卡片,则重新让卡片随机选择临时识别号,直到叫出一张卡片为止。

    这种办法不要求卡片有一个全球唯一序列号,所以卡片的生产数量没有限制,但是理论上存在一种可能,就是有一张卡永远也选不出来。


    3.位和时隙相结合的防冲突机制


    ISO15693中使用这种机制。一方面每张卡片有一个7字节的全球唯一序列号,另一方面读写器在防冲突的过程中也使用时隙叫号的方式,不过这里的号不是卡片随机选择的,而是卡片唯一序列号的一部分。


    叫号的数值范围分为0-1和0-15两种。其大体过程是,当有多张卡片进入射频场,读写器发出清点请求命令,假如指定卡片的叫号范围是0-15,则卡片序列号最低4位为0000的卡片回送自己的7字节序列号。如果没有冲突,卡片的序列号就被登记在PCD中。然后读写器发送一个帧结束标志,表示让卡片序列号最低4位为0001的卡片作出应答;之后读写器每发送一个帧结束标志,表示序列号的最低4位加1,直到最低4位为1111的卡片被要求应答。如果此过程中某一个卡片回送序列号时没有发生冲突,读写器就可选择此张卡片;如果巡检过程中没有卡片反应,表示射频场中没有卡片;如果有卡片反应的时隙发生了冲突,比如最低4位是1010的卡片回送卡号时发生了冲突,则读写器在下一次防冲突循环中指定只有最低4位是1010的卡片参与防冲突,然后用卡片的5-8位作为时隙,重复前面的巡检。如果被叫卡片的5-8位时隙也相同,之后再用卡片的9-12位作为时隙,重复前面的巡检,依次类推。读写器可以从低位起指定任意位数的序列号,让卡号低位和指定的低位序列号相同的卡片参与防冲突循环,卡片用指定号前面的一位或4位作为时隙对读写器的叫号作出应答。由于卡片的序列号全球唯一,所以任何两张卡片总有某个连续的4位二进制数不一样,因而总能选出一张卡片。


    另外需要说明的是,TTF(Tag Talk First)的卡片一般是无法防冲突的。这种卡片一进入射频场就主动发送自己的识别号,当有多张卡片同时进入射频场时就会发生不读卡的现象。这时只有靠卡片的持有者自己去避免冲突了。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值