How to make “MessageDigest SHA-1 and Signature NONEwithRSA” equivalent to “Signature SHA1withRSA ”

后端 未结 2 457
陌清茗
陌清茗 2021-02-03 14:47

I am interested in applying a SHA-1 hash with RSA signature to some data, but I need to do it in two steps - apply hash first and then sign the data. The Signature.sign() funct

2条回答
  •  梦毁少年i
    2021-02-03 15:28

    emsworth's answer was when a great help for me when struggling with the same issue (but using SHA512). However it is still missing a hint which takes me a few more days to find out by myself.

    There are different ways how the signature is constructed. For example when using RSASSA-PKCS1-v1_5 (from RFC 5246, TLS 1.2) the DER-encoded DigestInfo is not obtained the usual way. For example if using BouncyCastle

    DigestInfo digestInfo = new DigestInfo(new AlgorithmIdentifier(NISTObjectIdentifiers.id_sha512), hash);
    byte[] digestedHash = digestInfo.getEncoded(ASN1Encoding.DER);
    

    does not yield the expected results. RFC 3447 defines how to construct the DER encoding on page 42. For example in case of SHA-512 the DER encoding is as follows:

    // code example includes MessageDigest for the sake of completeness
    byte[] input = ... // the raw data
    MessageDigest md = MessageDigest.getInstance("SHA-512");
    md.update(input);
    byte[] hash = md.digest();
    
    // Taken from RFC 3447, page 42 for SHA-512, create input for signing
    byte[] modifierBytes = { 0x30, 0x51, 0x30, 0x0d, 0x06, 0x09, 0x60, (byte) 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x02, 0x03, 0x05, 0x00, 0x04, 0x40 };
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    baos.write(modifierBytes);
    baos2.write(hash);
    
    // create signature
    Signature s = Signature.getInstance("NONEwithRSA");
    s.initSign(MyTlsCredentials.THE_CLIENT_KEY);
    s.update(baos.toByteArray());
    byte[] signature = s.sign();
    
    // add prefix as specified in RFC 3447, im my case it had always been the shown values
    // but I have not understand the RFC completely in this point as the code seems to be
    // contradictious to the interpretation of the byte values for the hash function from page 42.
    ByteArrayOutputStream baos2 = new ByteArrayOutputStream();
    baos2.write(new byte[] { 1, 0 });
    baos2.write(signature5);
    

提交回复
热议问题