https://www.jianshu.com/p/be45fa5b88d4?from=groupmessage
几乎所有的需要在卡片和终端之间传送的数据都是TLV格式的.
我给你举个例子方便快速理解:TLV
是tag
, length
和value
的缩写.一个基本的数据元就包括上面三个域. Tag
唯一标识该数据元, length
是value
域的长度. Value就是数据本身了. 举个例子, 下面是一个tlv格式的AID(应用标识符)字节串”9F0607A0000000031010
”, 其中9F06
是tag, 07
是长度, A0000000031010
就是AID本身的值了.
对于程序编写人员来说,如果有类似上面这样的一串TLV编码的字节串从卡片传过来, 怎么样从中提取我们想要的数据. 这就牵扯出TLV解码的问题了
TLV一种可变格式,TLV的意思就是:Type类型, Lenght长度,Value值;
Type和Length的长度固定,一般那是2、4个字节;
Value的长度有Length指定;
解析方法:
1.读取type 转换为ntohl、ntohs转换为主机字节序得到类型;指针偏移+2或4
2.读取lenght,转换为ntohl、ntohs转换为主机字节序得到长度;指针偏移+2或4
3.根据得到的长度读取value,指针偏移+Length;
TLV编码就是指先对Tag编码,再对Length编码,最后对Value编码。
作者:FantJ
链接:https://www.jianshu.com/p/be45fa5b88d4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
BER编码的一种,ASN1标准,全称Tag(标签),Length(长度),Value(值)。
IS-IS数据通信领域中,tlv三元组: tag-length-value(TLV)。T、L字段的长度往往固定(通常为1~4bytes),V字段长度可变。顾名思义,T字段表示报文类型,L字段表示报文长度、V字段往往用来存放报文的内容。
现在有这么一个二进制字节流
6F328407A0000000031010A5278701019F38129F1A029F33039F40059F1B049F09029F35015F2D086573656E667264659F110101
如第一行所示,它就是一个由上面buf解析出来的TLV结构
tag为6F,lenth为32,后面为value;
对于TLV来讲,有两种格式,一种是基本格式(BER-TLV),一种是嵌套格式
对于本例的buf来讲,它就是一个复合的嵌套格式,完整解析出来应该是这个样子
整个buf是一个父节点,6F
他有两个子节点84 、A5
对于84节点,他是不可再分的基础格式
对于A5节点,他是一个父节点
可以再拆分为4个子节点87、 9F38、 5F2D、 9F11
tag详细结构表:
分为3部分,最高两位,第六位和低五位,其具体表示含义如图;
编码规则
第一个字节 bit8~bit7 表明tag所属类型
00 通用级 universal class
01 应用级 application class
10 规范级 context-specific class
11 私有级 private class
在智能卡中见得较多的是应用类与上下文相关类,通用类与行业无关,好像只有一个(0x06:Object Identifier);应用类就很多了,如前文中的0x6F,还有经常碰到的0x4F表示AID(应用标识符),在7816中定义,在其它很多的应用中就遵循了,如EMV,PBOC,GP等。
第一个字节 bit6 表明本tag的value部分是否包含子tag
第一个字节 bit5~bit1 表明是否有第二个字节一起表示本tag
11111 全为1表示有第二个字节
第二个字节 bit8 为1,同时bit7~bit1 大于0 表示有下一个tag
第三~N个字节同第二个字节
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
总结:编码解析和过程:1)根据第一个字节分解,bit1–bit5判断tag长度,bit6判断是否是复合tag;
2)根据tag长度,找到len,根据len画出后面数据长度;
3)根据是否是复合结构,继续循环如上分解过程;
后续更新代码操作;
https://blog.csdn.net/Enjoy_endless/article/details/75108349
https://www.cnblogs.com/zhengweifang/p/11549337.html
https://blog.csdn.net/kxd_ysheng/article/details/21178101
https://blog.csdn.net/xuture/category_1477475.html
https://blog.csdn.net/xuture/article/details/9250067
https://blog.csdn.net/kxd_ysheng/article/details/40512551