Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-6255949

Allow a negative modulus value when DER decoding an RSA public key

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Fixed
    • Icon: P4 P4
    • 6
    • 5.0, 5.0u2
    • security-libs
    • None
    • beta
    • generic, sparc
    • generic, solaris_9

        The CA certificate store on Microsoft Windows contains an RSA public-key
        certificate that is encoded incorrectly. See attachments. Its modulus value is
        DER encoded as a negative integer instead of a positive integer. Our DER parser
        rejects such an encoding and therefore the enclosing certificate cannot be
        parsed.

        The DER encoding for the key's modulus value is:

            INTEGER
                81 55 22 B9 8A A4 6F ED D6 E7 D9 66 0F 55 BC D7
                CD D5 BC 4E 40 02 21 A2 B1 F7 87 30 85 5E D2 F2
                44 B9 DC 9B 75 B6 FB 46 5F 42 B6 9D 23 36 0B DE
                54 0F CD BD 1F 99 2A 10 58 11 CB 40 CB B5 A7 41

        The correct DER encoding is:

            INTEGER
                00 81 55 22 B9 8A A4 6F ED D6 E7 D9 66 0F 55 BC
                D7 CD D5 BC 4E 40 02 21 A2 B1 F7 87 30 85 5E D2
                F2 44 B9 DC 9B 75 B6 FB 46 5F 42 B6 9D 23 36 0B
                DE 54 0F CD BD 1F 99 2A 10 58 11 CB 40 CB B5 A7
                41

        Given that this certificate is already widely deployed on Windows
        installations, our code needs to be able to parse it in the interests of
        interoperability.

        ###@###.### 2005-04-15 15:36:11 GMT

              vinnie Vincent Ryan
              vinnie Vincent Ryan
              Votes:
              0 Vote for this issue
              Watchers:
              0 Start watching this issue

                Created:
                Updated:
                Resolved:
                Imported:
                Indexed: