我有一个 X.509 证书,其中包含一组具有以下隐式 [0] 标记的数据:
A0 81 C6 (value)...
我有一份标准文件的摘录:
IMPLICIT [0] 标签不用于 DER 编码,而是使用 EXPLICIT SET OF 标签。也就是说,EXPLICIT SET OF 标记的 DER 编码,而不是 IMPLICIT [0] 标记的编码,必须与值的长度和内容八位字节一起包含。
我已经做了很多搜索,但我无法弄清楚标准要求什么。我正在寻找一些澄清。
编辑:这是我遵循的标准:https ://www.rfc-editor.org/rfc/rfc3852
我正在尝试验证 X.509 签名,我需要计算消息摘要来执行此操作。此证书包括 SignerInfo 类型中的可选 SignedAttributes。我已经对签名内容进行了哈希处理,并验证了 SignedAttributes 中的消息摘要是否正确。该标准规定,如果存在 SignedAttributes,则应对其进行散列和加密以创建证书的签名。该标准还说,应按照原始问题中的讨论更改 SignedAttributes 的标签。
这是 SignerInfo 的 Asn.1 语法:
SignerInfo ::= SEQUENCE {
version CMSVersion,
sid SignerIdentifier,
digestAlgorithm DigestAlgorithmIdentifier,
signedAttrs [0] IMPLICIT SignedAttributes OPTIONAL,
signatureAlgorithm SignatureAlgorithmIdentifier,
signature SignatureValue,
unsignedAttrs [1] IMPLICIT UnsignedAttributes OPTIONAL }
SignerIdentifier ::= CHOICE {
issuerAndSerialNumber IssuerAndSerialNumber,
subjectKeyIdentifier [0] SubjectKeyIdentifier }
SignedAttributes ::= SET SIZE (1..MAX) OF Attribute
UnsignedAttributes ::= SET SIZE (1..MAX) OF Attribute
Attribute ::= SEQUENCE {
attrType OBJECT IDENTIFIER,
attrValues SET OF AttributeValue }
AttributeValue ::= ANY
SignatureValue ::= OCTET STRING