首页 » 技术分享 » TLV编码结构详解

TLV编码结构详解

 

项目需要、糊里糊涂也能用,但总是感觉不踏实、不属于自己,所以网上收集整理、学习如下;

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)根据第一个字节分解,bit1–bit5判断tag长度,bit6判断是否是复合tag;
2)根据tag长度,找到len,根据len画出后面数据长度;
3)根据是否是复合结构,继续循环如上分解过程;

后续更新代码操作;

转载自原文链接, 如需删除请联系管理员。

原文链接:TLV编码结构详解,转载请注明来源!

0