繁体   English   中英

在EMV事务中解析PDOL以获取GET PROCESSING OPTIONS命令

[英]Parsing PDOL for GET PROCESSING OPTIONS command in EMV transaction

我正在尝试构建一个格式正确的GET PROCESSING OPTIONS命令,以发送到非接触式EMV卡。 这篇文章非常有用,但我只需要了解更多细节。

在解析PDOL时,可以安全地假设每个标记的长度为2个字节,然后是预期的数据大小吗?

例如,PDOL 9F66049F02069F37049F1A02分为9F66 04 9F02 06等,每个都有2个字节的标签,1个字节用于预期的数据长度。

在解析时假设每个标记的长度是2个字节是否安全?

不,你不能指望每个标签都包含两个字节(尽管大多数标签都有)。 EMV中的标签长度​​值(TLV)结构遵循ASN.1编码规则(基本编码规则,BER)。 有关详细信息,请参阅以下文档:

后者是一个非常好的介绍,帮助我入门。

TLV结构(数据对象)由标记值,长度值和数据有效负载(值)组成:

+-----------+-----------+-----------+
|    Tag    |  Length   |   Value   |
| (N Bytes) | (M Bytes) | (L bytes) |
+-----------+-----------+-----------+

PDOL(以及任何其他数据对象列表,DOL)包含标记和一个或多个此类数据对象的长度部分。 类似地,PDOL相关数据包含PDOL中引用的DO的值部分。 标签和长度部分都可以包含一个或多个字节。

对于标记部分,规则与此类似(有关详细信息,请参阅上述参考):

  • 如果第一个标记字节的低5位全部为1( tag[0] & 0x01F == 0x01F ),则标记至少包含两个字节。
  • 如果下一个标记字节的高位是1( tag[i] & 0x080 == 0x080 ),则标记由另外一个字节组成。 对于每个后续字节重复此操作。

对于长度部分,规则大约是这样的(有关更多详细信息,请参阅上面的参考资料):

  • 如果第一长度字节的高位为零( length[0] & 0x080 == 0 ),则剩余的7位编码长度值( length[0] & 0x07F )。
  • 如果第一长度字节的高位是1( length[0] & 0x080 == 0x080 ),则剩余的7位编码长度部分的剩余字节数( length[0] & 0x07F )。 其余字节表示长度值为无符号整数,MSB优先。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM