Cómo añadir la extensión PrivateKeyUsage a un certificado mediante BouncyCastle en Java?
-
28-09-2019 - |
Pregunta
tengo una X509Certificate que quiero añadir extensiones a ... Quiero añadir la extensión PrivateKeyUsage, pero no sé cómo crear un objeto PrivateKeyUsage o cómo darle notBefore y notAfter valores ... gracias
Solución
Date from = new Date();
Date to = new Date(System.currentTimeMillis()+ 30*1000*60*60l);
ASN1EncodableVector v = new ASN1EncodableVector();
DERGeneralizedTime fromTime = new DERGeneralizedTime(from);
v.add(new DERTaggedObject(false, 0, fromTime));
DERGeneralizedTime toTime = new DERGeneralizedTime(to);
v.add(new DERTaggedObject(false, 1, toTime));
DERObject o = new DERSequence(v);
PrivateKeyUsagePeriod pkup = PrivateKeyUsagePeriod.getInstance(o);
v3CertGen.addExtension(x509Extensions.PrivateKeyUsagePeriod, false, pkup);
Otros consejos
Puede hacer algo como esto,
Date notBeforeDate = new Date();
Date notAfterDate = new Date(System.currentMillis() + 24L*3600*365*1000);
PrivateKeyUsagePeriod pkup = new PrivateKeyUsagePeriod(notBeforeDate,
notAfterDate);
V3Extension[] v3 = {pkup};
cert = CertificateFactory.createCertificate(subject, kp.getPublic(), issuer,
kp.getPrivate(), algorithm, 1, v3);
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow