標籤:
本文是自身在研究學習過程中碰到的問題,整理而成。
為了便於後文的引用說明,先列出一段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
根據ISO/IEC 8825-1(doc88上可以查看較早版本 )規範的定義,BER-TLV結構由Tag、Length、Value三部分組成;
Tag可以由1個與多個位元組組成,如所示:
其中最為主要的是首位元組,由三部分組成,高兩位表示類別,低五位表示TagNumber,第6位表示類型;
首位元組的解析EMV規範中的一張圖說明很詳細,國內也可以參考PBOC規範。
由可以看出,高兩位表示的四種類別,分別為:
00:通用類
01:應用類
02:上下文相關類
03:專用類
在智慧卡中見得較多的是應用類與上下文相關類,通用類與行業無關,好像只有一個(0x06:Object Identifier);應用類就很多了,如前文中的0x6F,
還有經常碰到的0x4F表示AID(應用標識符),在7816中定義,在其它很多的應用中就遵循了,如EMV,PBOC,GP等。
0x6F: ‘0110 1111‘
0x4F: ‘0100 1111‘
上下文類在特定的使用環境中意義不一樣,具體可以參考相應的規範定義。專用類一般在私人的定義中出現,例如一些卡商在卡片的預個人化命令中使用。
對於各類別表示的範圍如上表所示,該表格來自《智慧卡技術》一書。
Tag的類型由第6位表示,
0:表示簡單類型
1:表示結構類型
可以用一個比喻來理解兩種類型的區別,簡單類型相當於樹形結構中的葉子節點,結構類型相當於枝幹。例如如下的資料中,
84、50、87等處在葉子節點上的tag就表示簡單類型,而6F、A5等表示結構類型。用二進位表示更為直觀理解。
0x6F: ‘0110 1111‘
0x50: ‘0101 0000‘
Tag編號要根據Tag的長度來確定,對於一個位元組的Tag,能表示的編號為2^5為32,但全為1的時候表示有後續位元組,
因此一個位元組的tag只能表示31個編號,大於31的只能由第多個位元組表示;
在平常使用中感覺很少碰到,只在JavaCard的一個demo中使用過(說到這裡順便提下,在JavaCard提供的API中,
有一個包專門為TLV提供資料打包與解析。但在使用過程中碰到一個問題,類似前文中例子中的9F11這個Tag解析不了)。
如所示,根據解析得到TAG9F11的Tag編號為0x11,個人理解此處的0x10應該表示的編號為(0x11+31)。
BER-TLV中的長度表示Value域中的資料長度,由1到多個位元組組成,如果首位元組的最高位為0,則低7位表示長度,
最大值為0x7F,Value資料長度大於128個位元組則Length都由3個位元組表示。對於超過256位元組較少見到,
JavaCard中的下載檔案時使用的Tag經常用到,擴充APDUs可能用到。
值由一個或多個位元組組成,根據Tag中的類型不同,有簡單類型及結構類型兩種表示方法,如本文最開始提供的資料中,
tag6F的資料長度為0x4D,範圍為後面所有的資料。
- 資料引用
- ISO/IEC 8825-1規範:http://www.doc88.com/p-864119027073.html
- EMV規範:EMV:Book3
- 《智慧卡技術》第四版
BER-TLV資料結構