700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > java生成公钥和私钥_使用Java生成证书 公钥和私钥

java生成公钥和私钥_使用Java生成证书 公钥和私钥

时间:2022-04-26 18:19:13

相关推荐

java生成公钥和私钥_使用Java生成证书 公钥和私钥

小编典典

您可以使用一对或密钥在Java中动态生成证书。(公钥,私钥)。以BigInteger格式获取这些密钥,并检查以下代码以生成证书。

RSAPrivateKeySpec serPrivateSpec = new RSAPrivateKeySpec(

new BigInteger(val of pub key), new BigInteger(val of pri key));

fact = KeyFactory.getInstance("RSA");

PrivateKey serverPrivateKey = fact.generatePrivate(serPrivateSpec);

RSAPublicKeySpec serPublicSpec = new RSAPublicKeySpec(

new BigInteger(agentCL.getSerPubMod()), new BigInteger(agentCL.getSerPubExp()));

PublicKey serverPublicKey = fact.generatePublic(serPublicSpec);

keyStore = KeyStore.getInstance(IMXAgentCL.STORE_TYPE);

keyStore.load(null, SOMEPWD.toCharArray());

Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());

X509Certificate[] serverChain = new X509Certificate[1];

X509V3CertificateGenerator serverCertGen = new X509V3CertificateGenerator();

X500Principal serverSubjectName = new X500Principal("CN=OrganizationName");

serverCertGen.setSerialNumber(new BigInteger("123456789"));

// X509Certificate caCert=null;

serverCertGen.setIssuerDN(somename);

serverCertGen.setNotBefore(new Date());

serverCertGen.setNotAfter(new Date());

serverCertGen.setSubjectDN(somename);

serverCertGen.setPublicKey(serverPublicKey);

serverCertGen.setSignatureAlgorithm("MD5WithRSA");

// certGen.addExtension(X509Extensions.AuthorityKeyIdentifier, false,new

// AuthorityKeyIdentifierStructure(caCert));

serverCertGen.addExtension(X509Extensions.SubjectKeyIdentifier, false,

new SubjectKeyIdentifierStructure(serverPublicKey));

serverChain[0] = serverCertGen.generateX509Certificate(serverPrivateKey, "BC"); // note: private key of CA

keyStore.setEntry("xyz",

new KeyStore.PrivateKeyEntry(serverPrivateKey, serverChain),

new KeyStore.PasswordProtection("".toCharArray()));

希望这会帮助你。

-11-17

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。