OCTET 字符串

ASN.1 OCTET STRING 数据类型编码为 TLV 三元组,以0x04 标记 字节开头。 OCTET STRINGBIT STRING 数据类型非常相似。 因此,这两种类型采用类似的方式进行编码,不同之处在于,由于 OCTET STRING 的尾随字节 不能有未使用的位,因此,不得向内容添加前导字节。 以下示例改编自 CMC 编码 ASN.1 主题,演示如何将证书模板的名称编码为字节数组。

30 17                                 ; SEQUENCE (17 Bytes)
|  06 09                              ; OBJECT_ID (9 Bytes)
|  |  2b 06 01 04 01 82 37 14  02     ;   1.3.6.1.4.1.311.20.2
|  04 0a                              ; OCTET_STRING (a Bytes)
|     1e 08 00 55 00 73 00 65  00 72  ;   ...U.s.e.r

如果字节数组包含的字节数少于 128 个字节,则 TLV 三元组的 Length 字段只需要一个字节才能指定内容长度。 如果长度超过 127 字节,则 长度 字段的位 7 设置为 1,位 6 到 0 指定用于标识内容长度的其他字节数。 以下示例显示了第一行中第二个字节的高序位设置为 1,字节指示有尾随 长度 字节。 因此,第三个字节指定内容长度为0x80字节。

04 81 80                       ; OCTET_STRING (80 Bytes)
   38 10 60 e2 70 69 91 4a     ;   8.`.pi.J
   8b b5 22 57 2a 62 ef de     ;   .."W*b..
   15 7d 59 d6 4e 20 9a 45     ;   .}Y.N .E
   2b e3 fd fc 68 ba af bf     ;   +...h...
   9c 17 b0 8e 6d c4 29 1e     ;   ....m.).
   e3 21 ac bb 5a 8a c9 67     ;   .!..Z..g
   0a d4 45 93 10 c0 26 eb     ;   ..E...&.
   0a 83 c2 b1 40 87 36 f7     ;   ....@.6.
   a0 26 da b9 bb 46 73 88     ;   .&...Fs.
   7a 67 b9 e6 b3 6f ea 59     ;   zg...o.Y
   28 8a d3 92 72 f6 7b 89     ;   (...r.{.
   a0 d8 2d 9e 40 eb 1e bb     ;   ..-.@...
   6e ae f0 5a ed 16 c9 e3     ;   n..Z....
   27 59 37 8f f3 4a 98 60     ;   'Y7..J.`
   f8 fb a7 0a ee 1b 6e 91     ;   ......n.
   95 96 cf 0d 56 ac ab 35     ;   ....V..5

ASN.1 类型系统

ASN.1 类型的 DER 编码