本文整理汇总了Java中org.spongycastle.asn1.x509.GeneralName类的典型用法代码示例。如果您正苦于以下问题:Java GeneralName类的具体用法?Java GeneralName怎么用?Java GeneralName使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
GeneralName类属于org.spongycastle.asn1.x509包,在下文中一共展示了GeneralName类的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。
示例1: generateSelfSignedCertChain
import org.spongycastle.asn1.x509.GeneralName; //导入依赖的package包/类
private Certificate generateSelfSignedCertChain(KeyPair kp, X500Name subject, String hostname)
throws CertificateException, OperatorCreationException, IOException {
SecureRandom rand = new SecureRandom();
PrivateKey privKey = kp.getPrivate();
PublicKey pubKey = kp.getPublic();
ContentSigner sigGen = new JcaContentSignerBuilder(DEFAULT_SIG_ALG).build(privKey);
SubjectPublicKeyInfo subPubKeyInfo = new SubjectPublicKeyInfo(
ASN1Sequence.getInstance(pubKey.getEncoded()));
Date now = new Date(); // now
/* force it to use a English/Gregorian dates for the cert, hardly anyone
ever looks at the cert metadata anyway, and its very likely that they
understand English/Gregorian dates */
Calendar c = new GregorianCalendar(Locale.ENGLISH);
c.setTime(now);
c.add(Calendar.YEAR, 1);
Time startTime = new Time(now, Locale.ENGLISH);
Time endTime = new Time(c.getTime(), Locale.ENGLISH);
X509v3CertificateBuilder v3CertGen = new X509v3CertificateBuilder(
subject,
BigInteger.valueOf(rand.nextLong()),
startTime,
endTime,
subject,
subPubKeyInfo);
if (hostname != null) {
GeneralNames subjectAltName = new GeneralNames(
new GeneralName(GeneralName.iPAddress, hostname));
v3CertGen.addExtension(X509Extension.subjectAlternativeName, false, subjectAltName);
}
X509CertificateHolder certHolder = v3CertGen.build(sigGen);
return new JcaX509CertificateConverter().getCertificate(certHolder);
}
开发者ID:f-droid,项目名称:fdroidclient,代码行数:39,代码来源:LocalRepoKeyStore.java
示例2: generateCertificate
import org.spongycastle.asn1.x509.GeneralName; //导入依赖的package包/类
public static X509Certificate generateCertificate(KeyPair pair)
throws InvalidKeyException, NoSuchProviderException, SignatureException
{
// generate the certificate
X509V3CertificateGenerator certGen = new X509V3CertificateGenerator();
certGen.setSerialNumber(BigInteger.valueOf(System.currentTimeMillis()));
certGen.setIssuerDN(new X500Principal("CN=Restcomm Android SDK"));
certGen.setNotBefore(new Date(System.currentTimeMillis() - 50000));
// TODO: using 1 day for now, need to increase that
certGen.setNotAfter(new Date(System.currentTimeMillis() + 86400000));
certGen.setSubjectDN(new X500Principal("CN=Restcomm Android SDK"));
certGen.setPublicKey(pair.getPublic());
certGen.setSignatureAlgorithm("SHA1withECDSA");
certGen.addExtension(X509Extensions.BasicConstraints, true, new BasicConstraints(false));
certGen.addExtension(X509Extensions.KeyUsage, true, new KeyUsage(KeyUsage.digitalSignature | KeyUsage.keyEncipherment));
certGen.addExtension(X509Extensions.ExtendedKeyUsage, true, new ExtendedKeyUsage(KeyPurposeId.id_kp_serverAuth));
certGen.addExtension(X509Extensions.SubjectAlternativeName, false, new GeneralNames(new GeneralName(GeneralName.rfc822Name, "[email protected]")));
// provider is Bouncy Castle
return certGen.generateX509Certificate(pair.getPrivate(), "BC");
}
开发者ID:RestComm,项目名称:restcomm-android-sdk,代码行数:24,代码来源:JainSipSecurityHelper.java
注:本文中的org.spongycastle.asn1.x509.GeneralName类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论