Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7565898
  • 博文数量: 961
  • 博客积分: 15795
  • 博客等级: 上将
  • 技术积分: 16612
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-07 14:23
文章分类

全部博文(961)

文章存档

2016年(1)

2015年(61)

2014年(41)

2013年(51)

2012年(235)

2011年(391)

2010年(181)

分类: 嵌入式

2012-12-25 16:43:40

PBOCIC卡大部分数据都是TLV格式的. EMV的手册简单的编码规则说明我下面很详细的分析TLV的编码格式并给出相应的TLV解码的伪代码.

 

TLVtag, lengthvalue的缩写.一个基本的数据元就包括上面三个域. Tag唯一标识该数据元, lengthvalue域的长度. Value就是数据本身了举个例子下面是一个tlv格式的AID(应用标识符)字节串”9F0607A0000000031010其中9F06tag, 07是长度, A0000000031010就是AID本身的值了.

 

开发人员应该关心的是,如果有类似上面这样的一串TLV编码的字节串从卡片传过来怎么样从中提取我们想要的数据这就就是TLV解码的问题了.

 

其中BER-TLV编码是ISO定义一种规范然后到了PBOC/EMV里被简化了举一个例子, tag域在ISO里可以有多个字节,PBOC/EMV里规定只用前两个字节我下面要讲的TLV解码就是基于PBOC/EMV的简化版本.

 

首先看一下tag域是怎样编码的. Tag域最多占两个字节编码规则如下面两幅图

解释一下这两幅图第一个图是第一个字节的编码规则. b8b7两位标识tag所属类别这个可以暂时不用理.  b6决定当前的TLV数据是一个单一的数据和复合结构的数据复合的TLV是指value域里也包含一个或多个TLV, 类似嵌套的编码格式. b5~b1如果全为1,则说明这个tag下面还有一个子字节占两个字节否则tag占一个字节.

第二幅图是说明如果tag占用两个字节第二个字节的编码格式. B8决定tag是否还有后绪的字节存在,因为前面说过,PBOC/EMV里的tag最多占两个字节所以该位保持为0.

 

清楚了上面tag编码格式,可很容易写出tag域解码的代码了假设,终端接收到字节串,这个字节串保存在tlvData的字节数组里伪代码如下:


点击(此处)折叠或打开

  1. if ( (tlvData[i]&0x20) != 0x20)//单一结构
  2. {
  3.       if ( (tlvData[i]&0x1f) == 0x1f)//tag两字节
  4.        {
  5.              tagIndex++;
  6.   
  7.              //解析length域
  8.                //解析value域
  9.        }
  10.      else//tag单字节
  11.       {
  12.           //解析length域
  13.             //解析value域
  14.       }
  15. }
  16.  else//复合结构
  17.  {
  18.           //复合结构可以考虑用递归的方法来实现.
  19.  }

  Length域的编码比较简单,最多有四个字节如果第一个字节的最高位b80, b7~b1的值就是value域的长度如果b81, b7~b1的值指示了下面有几个子字节下面子字节的值就是value域的长度.Value域的编码格式要根据具体的value所表示的数据元决定比如AID是由RID+PIX构成等这个不详述有了上面的知识,基本上可以写一个TLV解码器出来了.  

阅读(2784) | 评论(0) | 转发(3) |
给主人留下些什么吧!~~