RFR: 8242068: Signed JAR support for RSASSA-PSS and EdDSA [v7]
Valerie Peng
valeriep at openjdk.java.net
Fri Oct 16 19:07:12 UTC 2020
On Fri, 16 Oct 2020 02:30:55 GMT, Weijun Wang <weijun at openjdk.org> wrote:
>> src/java.base/share/classes/sun/security/pkcs/PKCS7.java line 818:
>>
>>> 816: DerOutputStream derSigAlg = new DerOutputStream();
>>> 817: sigAlgID.derEncode(derSigAlg);
>>> 818: derAlgs.writeImplicit((byte)0xA1, derSigAlg);
>>
>> Are you sure that this context specific tag value is implicit? In RFC 6211, some other ASN.1 definition uses IMPLICIT
>> keyword after the [x] which seems to suggest that the default is explicit unless specified. Besides, the layman's guide
>> sec2.3 also states "The keyword [class number] alone is the same as explicit tagging, except when the "module" in which
>> the ASN.1 type is defined has implicit tagging by default." So, it seems that explicit tagging should be the default?
>
> In the formal definition at https://tools.ietf.org/html/rfc6211#appendix-A, you can see `DEFINITIONS IMPLICIT TAGS`
> covers from BEGIN to END. Those explicit IMPLICIT tags you see are CMS ASN.1 definitions, and it looks in its own RFC
> at https://tools.ietf.org/html/rfc5652#section-12, IMPLICIT and EXPLICIT are always written out. I can confirm both
> OpenSSL and BC use IMPLICIT.
Ah, I see. There is a line about implicit tags as you pointed out. Good~
>> src/java.base/share/classes/sun/security/pkcs/PKCS7.java line 172:
>>
>>> 170: throws IOException
>>> 171: {
>>> 172: ContentInfo block = new ContentInfo(derin, oldStyle);
>>
>> With this change, i.e. using a local variable instead of setting the field 'contentInfo', the 'contentInfo' field seems
>> to left unset when contentType equals to ContentInfo.NETSCAPE_CERT_SEQUENCE_OID?
>
> I'll see what the best code is, but I don't like the way contentInfo is assigned twice, once as the whole block and
> once as the content inside. I'd rather add a `contentInfo = block` in its else if block.
Right, I also dislike the double assignment. Just making sure that contentInfo is set somewhere.
-------------
PR: https://git.openjdk.java.net/jdk/pull/322
More information about the security-dev
mailing list