java - 使用 BouncyCaSTLe 创建 key 对证书并使用外部 CA 对其进行签名

标签 java security encryption x509certificate bouncycastle

到目前为止,这是我为用户生成证书的内容

    try {
        Security.addProvider(new BouncyCastleProvider()); // adding provider
                                                            // to
        String pathtoSave = "D://sureshtest.cer";

        KeyPair keyPair = generateKeypair();
        PublicKey publicKey = keyPair.getPublic();
        PrivateKey privateKey = keyPair.getPrivate();
        X509Certificate trustCert = createCertificate(null, "CN=CompanyName",
                "CN=Owner", publicKey, privateKey);
        java.security.cert.Certificate[] outChain = { trustCert, };
        trustCert.checkValidity();
        KeyStore outStore = KeyStore.getInstance("PKCS12");
        outStore.load(null, null);
        outStore.setKeyEntry("my own certificate", privateKey,
                "admin123".toCharArray(), outChain);
        OutputStream outputStream = new FileOutputStream(pathtoSave);
        outStore.store(outputStream, "admin123".toCharArray());
        outputStream.flush();
        outputStream.close();


    } catch (Exception e) {
        e.printStackTrace();
    }

以上代码生成一个带有私钥和公钥的证书。

现在我想用证书颁发机构 (CA) 颁发的签名证书签署该证书。之后我会将该证书授予用户。

我得到了一些输入 from here这似乎不是我的案例所需的答案。

无需完整实现,只需一个有效的过程或一些提示即可。

最佳答案

您需要生成一个 CSR,以便您可以从 Sign CSR using Bouncy Castle 调用代码这是使用 BC API。将此添加到您上面的代码中:

        final PKCS10 request = new PKCS10(publicKey);
        final String sigAlgName = "SHA1WithRSA"; // change this to SHA1WithDSA if it's a DSA key
        final Signature signature = Signature.getInstance(sigAlgName);
        signature.initSign(privateKey);
        final X500Name subject = new X500Name(trustCert.getSubjectDN().toString());
        final X500Signer signer = new X500Signer(signature, subject);

        // Sign the request and base-64 encode it
        request.encodeAndSign(signer);
        final ByteArrayOutputStream baos = new ByteArrayOutputStream();
        final PrintStream writer = new PrintStream(baos);
        request.print(writer);
        // Remove -----BEGIN NEW CERTIFICATE REQUEST----- and -----END NEW CERTIFICATE REQUEST-----
        final String requestBase64 = new String(baos.toByteArray());
        String withoutTags = requestBase64.substring(41);
        withoutTags = withoutTags.substring(0, withoutTags.length() - 39);

        // org.bouncycastle.pkcs.PKCS10CertificationRequestHolder
        final PKCS10CertificationRequest holder = new PKCS10CertificationRequest(Base64.decode(withoutTags));
        // Feed this into https://stackoverflow.com/questions/7230330/sign-csr-using-bouncy-castle

关于java - 使用 BouncyCaSTLe 创建 key 对证书并使用外部 CA 对其进行签名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21375381/

相关文章:

ios - 为什么增加 CCKeyDerivationPBKDF 的轮数会提高安全性?

java - (源代码很大)初学者Java项目,很多问题,与加密字母表有关

database - 加盐密码哈希有什么好处?

java - 无法通过管理控制台在 JBoss 6.1 EAP 上进行非托管部署

java - 当用户单击“否”时,如何退出 JOptionPane 的 while 循环?

java - 如何在 Java 中插入 Oracle 日期数据类型

java - 使用java进行RSA解密失败

java - 在 Linux 上安装最新的 Java 版本

c# - 部分 View 和元素的 MVC 授权

python - Apache SSL 与 Python 简单 HTTP 服务器 SSL 安全问题