日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java证书cert_java – 使用带有证书路径(cert chain)的bouncy...

發布時間:2024/3/13 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java证书cert_java – 使用带有证书路径(cert chain)的bouncy... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Hy Guys!我正在嘗試使用bouncycastle創建x.509證書,該證書應該由另一個證書簽名并存儲為PEM base 64格式.

我已經擁有自簽名證書(公鑰和私鑰).現在我想創建一個新的,并使用現有的自簽名證書簽名.

KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA", "BC");

keyPairGenerator.initialize(1024, new SecureRandom());

KeyPair keyPair = keyPairGenerator.generateKeyPair();

X509V3CertificateGenerator certGen = new X509V3CertificateGenerator();

X500Principal dnName = new X500Principal("CN=Sergey");

certGen.setSerialNumber(BigInteger.valueOf(System.currentTimeMillis()));

certGen.setSubjectDN(dnName);

certGen.setIssuerDN(caCert.getSubjectX500Principal());

certGen.setNotBefore(validityBeginDate);

certGen.setNotAfter(validityEndDate);

certGen.setPublicKey(keyPair.getPublic());

certGen.setSignatureAlgorithm("SHA256WithRSAEncryption");

certGen.addExtension(X509Extensions.AuthorityKeyIdentifier, false, new AuthorityKeyIdentifierStructure(caCert));

certGen.addExtension(X509Extensions.SubjectKeyIdentifier, false, new SubjectKeyIdentifierStructure(keyPair.getPublic()));

X509Certificate cert = certGen.generate(caCertPrivateKey, "BC");

驗證通過沒有例外,這意味著從我的角度來看,它是由caCert成功簽署的:

cert.verify(caCert.getPublicKey());

然后我解碼它到PEM基地64:

PEMWriter pemWriter = new PEMWriter(new PrintWriter(System.out));

pemWriter.writeObject(cert);

pemWriter.flush();

我在輸出中得到這樣的東西:

—–開始認證—–

MIIDDjCCAnegAwIBAgIBFDAN ……..

—–證書結束—–

當我打開它,我看到下一個:

為什么沒有通過caCert成功簽名的認證鏈?

我的代碼需要更改才能看到我所期望的認證鏈?

總結

以上是生活随笔為你收集整理的java证书cert_java – 使用带有证书路径(cert chain)的bouncy...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。