私はJava(バウンシーキャッスルライブラリを使用)をCA証明書にコーディングしました。私は特定の秘密鍵でエンドエンティティ証明書に署名する必要があります。特定の秘密鍵を使用してCA証明書によってエンドエンティティcerteficateに署名する方法
X500Principal dnNameIssuer = new X500Principal("CN=\"" + hashedValue + " CA\", OU=PKI, O=\"" + hashedValue + ", Inc\", L=Darmstadt, ST=Hessen, C=DE");
X500Principal dnNameSubject = dnName;
serialNumber = new BigInteger("123127956789") ;
keyus = new KeyUsage(KeyUsage.digitalSignature);
ContentSigner signer = new JcaContentSignerBuilder("SHA512withECDSA").build(myprivateKey);
Date D1 = new Date(System.currentTimeMillis() - 24 * 60 * 60 * 1000);
Date D2 = new Date(System.currentTimeMillis() - 24 * 60 * 60 * 1000);
AuthorityKeyIdentifier AKI = new AuthorityKeyIdentifier(keyBytesPublic);
X509v3CertificateBuilder certBldr = new JcaX509v3CertificateBuilder(certroot,serialNumber, D1, D2, dnName, mypublicKey);
certBldr.addExtension(X509Extension.authorityKeyIdentifier, true, AKI);
certBldr.addExtension(X509Extension.subjectAlternativeName, false,new GeneralNames(new GeneralName(GeneralName.rfc822Name,"PNeODZ3wV5m2UXmJiovxdwPKZdCkB87ESsk7H8vTZKU=")));
certBldr.addExtension(X509Extensions.KeyUsage, true, keyus);
certBldr.addExtension(new ASN1ObjectIdentifier("2.5.29.19"), false, new BasicConstraints(false));
// Build/sign the certificate.
X509CertificateHolder certHolder = certBldr.build(signer);
X509Certificate Endcert = new JcaX509CertificateConverter().setProvider("BC").getCertificate(certHolder);
`
私はエラーあなたが私を助けることができるenter image description here
を得た: はここに私のコードです。または、誰かが私のために喜ぶCA証明書によってエンドエンティティ証明書に署名する別の方法があるとき。
おかげ