TLV

https://blog.csdn.net/Enjoy_endless/article/details/78259529?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.control

https://www.jianshu.com/p/be45fa5b88d4?from=groupmessage

几乎所有的需要在卡片和终端之间传送的数据都是TLV格式的.
我给你举个例子方便快速理解:
TLVtag, lengthvalue的缩写.一个基本的数据元就包括上面三个域. Tag唯一标识该数据元, lengthvalue域的长度. 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/liwei16611/article/details/84075019?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.control

https://blog.csdn.net/Enjoy_endless/article/details/75108349

https://www.cnblogs.com/zhengweifang/p/11549337.html

https://blog.csdn.net/weixin_33968104/article/details/94602153?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.control&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.control

https://blog.csdn.net/freud_lv/article/details/7557702?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-1.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-1.control

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值