BER-TLV数据结构

本文是自身在研究学习过程中碰到的问题,整理而成。

为了便于后文的引用说明,先列出一段TLV结构的数据:

[6F] 4D
│ ├─[84] 07 A0000003330101
│ ├─[A5] 42
│ │ ├─[50] 0B 50424F4320437265646974
│ │ ├─[87] 01 01
│ │ ├─[9F38] 06 9F33039F4E14
│ │ ├─[5F2D] 08 7A68656E66726465
│ │ ├─[9F11] 01 01
│ │ ├─[9F12] 0F 4341524420494D4147452030303031
│ │ ├─[BF0C] 05
│ │ │ └─[9F4D] 02 0B0A
  • BER-TLV数据对象结构

  • Tag(标记)

根据ISO/IEC 8825-1(doc88上可以查看较早版本 )规范的定义,BER-TLV结构由Tag、Length、Value三部分组成;

Tag可以由1个与多个字节组成,如下图所示:

其中最为主要的是首字节,由三部分组成,高两位表示类别,低五位表示TagNumber,第6位表示类型;

  • Tag类别

首字节的解析EMV规范中的一张图说明很详细,国内也可以参考PBOC规范。

由上图可以看出,高两位表示的四种类别,分别为:

00:通用类

01:应用类

02:上下文相关类

03:专用类

在智能卡中见得较多的是应用类与上下文相关类,通用类与行业无关,好像只有一个(0x06:Object Identifier);应用类就很多了,如前文中的0x6F,

还有经常碰到的0x4F表示AID(应用标识符),在7816中定义,在其它很多的应用中就遵循了,如EMV,PBOC,GP等。

0x6F: ‘0110 1111‘

0x4F: ‘0100 1111‘

上下文类在特定的使用环境中意义不一样,具体可以参考相应的规范定义。专用类一般在私有的定义中出现,例如一些卡商在卡片的预个人化命令中使用。

对于各类别表示的范围如上表所示,该表格来自《智能卡技术》一书。

  • Tag类型

Tag的类型由第6位表示,

0:表示简单类型

1:表示结构类型

可以用一个比喻来理解两种类型的区别,简单类型相当于树形结构中的叶子节点,结构类型相当于枝干。例如如下的数据中,

84、50、87等处在叶子节点上的tag就表示简单类型,而6F、A5等表示结构类型。用二进制表示更为直观理解。

0x6F: ‘0110 1111‘

0x50: ‘0101 0000‘

  • Tag编号

Tag编号要根据Tag的长度来确定,对于一个字节的Tag,能表示的编号为2^5为32,但全为1的时候表示有后续字节,

因此一个字节的tag只能表示31个编号,大于31的只能由第多个字节表示;

在平常使用中感觉很少碰到,只在JavaCard的一个demo中使用过(说到这里顺便提下,在JavaCard提供的API中,

有一个包专门为TLV提供数据打包与解析。但在使用过程中碰到一个问题,类似前文中例子中的9F11这个Tag解析不了)。

如上图所示,根据解析得到TAG9F11的Tag编号为0x11,个人理解此处的0x10应该表示的编号为(0x11+31)。

  • Length(长度)

BER-TLV中的长度表示Value域中的数据长度,由1到多个字节组成,如果首字节的最高位为0,则低7位表示长度,

最大值为0x7F,Value数据长度大于128个字节则Length都由3个字节表示。对于超过256字节较少见到,

JavaCard中的下载文件时使用的Tag经常用到,扩展APDUs可能用到。

  • Value(值)

值由一个或多个字节组成,根据Tag中的类型不同,有简单类型及结构类型两种表示方法,如本文最开始提供的数据中,

tag6F的数据长度为0x4D,值域为后面所有的数据。

时间: 2025-01-05 15:15:10

BER-TLV数据结构的相关文章

Redis 基础数据结构与对象

Redis用到的底层数据结构有:简单动态字符串.双端链表.字典.压缩列表.整数集合.跳跃表等,Redis并没有直接使用这些数据结构来实现键值对数据库,而是基于这些数据结构创建了一个对象系统,这个系统包括字符串对象.列表对象.哈希对象.集合对象和有序结合对象共5种类型的对象. 1 简单动态字符串 redis自定义了简单动态字符串数据结构(sds),并将其作为默认字符串表示. struct sdshdr { unsigned int len; unsigned int free; char buf[

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. 根据得到的长度读取 va

SNMP++ 04-SNMP中OBJECT IDENTIFIER的BER编码与解码及一些思考

阅读完本文你可以学到: (1)SNMP 中 OBJECT IDENTIFIER 的 BER 编码与解码代码实现. (2)在学习 OBJECT IDENTIFIER 编解码过程中的一些思考(思考过后,懂得当涉及对无符号数组进行传输编码时,可以给出一个较佳的方案). (3)snmp++-3.3.7 版本中函数 asn_parse_objid 存在的 bug. 一.理论知识 1.Tag OBJECT IDENTIFIER 对应的 Tag 为 0x06,占用一个八位组. 2.Length Length有

SNMP++ 02-SNMP中INTEGER的BER编码与解码

阅读完本文你可以学到: (1)BER 中 INTEGER 的编码规则(其中1.2.3主要引自<ASN.1编码规则详解.doc>(作者不详,该文档可在CSDN资源中搜索到)). (2)SNMP 中 INTEGER 的编码及解码实现(主要参考 net-snmp源码和 snmp++源码).本文仅对编码相关函数进行了详细的解释.理解它,或许是我们走向自己实现 SNMP 协议的第一步. 特别声明: (1)感谢<ASN.1编码规则详解.doc>作者所做的工作. (2)感谢所有为 net-snm

Redis中的数据结构

1. 底层数据结构, 与Redis Value Type之间的关系 对于Redis的使用者来说, Redis作为Key-Value型的内存数据库, 其Value有多种类型. String Hash List Set ZSet 这些Value的类型, 只是"Redis的用户认为的, Value存储数据的方式". 而在具体实现上, 各个Type的Value到底如何存储, 这对于Redis的使用者来说是不公开的. 举个粟子: 使用下面的命令创建一个Key-Value $ SET "

序列化之 TLV

目录 序列化之 TLV 1. 紧凑模式 2. 可扩展性 3. 更好的可扩展性 4. 自解释性 5. 跨语言特性 6. 代码自动化:IDL语言 7. 总结 序列化之 TLV 通信协议可以理解两个节点之间为了协同工作实现信息交换,协商一定的规则和约定,例如规定字节序,各个字段类型,使用什么压缩算法或加密算法等.常见的有 tcp,udo,http,sip 等常见协议.协议有流程规范和编码规范.流程如呼叫流程等信令流程,编码规范规定所有信令和数据如何打包/解包. 编码规范就是我们通常所说的编解码,序列化

【数据结构】之散列链表(Java语言描述)

散列链表,在JDK中的API实现是 HashMap 类. 为什么HashMap被称为"散列链表"?这与HashMap的内部存储结构有关.下面将根据源码进行分析. 首先要说的是,HashMap中维护着的是一个数组: transient Node<K,V>[] table; ,数组中的每个元素都是一个 Node 对象.这里的Node是HashMap的一个内部类,代码如下: static class Node<K,V> implements Map.Entry<

旧题新做:从idy的视角看数据结构

“今天你不写总结……!!!” 额…… 还是讲我的吧.这些考试都是idy出的题. 20170121:DFS序. ST表.线段树练习 这是第一次考数据结构. Problem 1. setsum 1 second 给你一个长度为N 的整数序列,支持两种操作: • modity l r val 将区间[l,r] 中的所有数修改为val • query l r 询问区间[l,r] 所有数的和 分析:最简单的线段树,区间更改区间求和.但注意是更改,不是添改,sum与flag需同时覆盖. Problem 2.

数据结构Set和Map

一.数据结构 Set 集合的基本概念:集合是由一组无序且唯一(即不能重复)的项组成的.这个数据结构使用了与有限集合相同的数学概念,应用在计算机的数据结构中.  特点:key 和 value 相同,没有重复的 value.ES6 提供了数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. 1. 如何创建一个 Set const s = new Set([1, 2, 3]); 2.属性 console.log(s.size); // 3 3.Set 类的方法 --set.add(v

数据结构基本概念

什么是数据结构 "数据结构是数据对象,以及存在于该对象的实例和组成实例的数据元素之间的各种联系.这些联系可以通过定义相关的函数来给出"--Sartaj Sahni,<数据结构.算法与应用> "数据结构是ADT(抽象数据类型Abstract Data Type)的物理实现."--Clifford A.Shaffer,<数据结构与算法分析> "数据结构(data structture)是计算机中存储.组织数据的方式.通常情况下,经i想你