2016-06-10 5 views
1

Ich möchte ein CA-selbstsigniertes Zertifikat in Java erstellen. Ich habe bereits ein selbstsigniertes Zertifikat unter Verwendung von Hüpfburg erstellt, aber wie grundlegende Bedingungen zu diesem Zertifikat hinzugefügt werden, um CA-Zertifikat zu sein. DankWie erstellt man ein CA-Zertifikat in Java

+1

Bitte fügen Sie den Code, den Sie jetzt verwenden. Brauchen Sie Hilfe zum Codieren mit Bouncycastle oder zum Generieren eines CA-Zertifikats? – pedrofb

Antwort

0

können Sie diesen Code verwenden unten, um ein selbst signiertes Zertifikat mit basicConstraints Erweiterung zu erstellen:

public static Certificate selfSign(KeyPair keyPair, String subjectDN) throws OperatorCreationException, CertificateException, IOException 
{ 
    Provider bcProvider = new BouncyCastleProvider(); 
    Security.addProvider(bcProvider); 

    long now = System.currentTimeMillis(); 
    Date startDate = new Date(now); 

    X500Name dnName = new X500Name(subjectDN); 
    BigInteger certSerialNumber = new BigInteger(Long.toString(now)); // <-- Using the current timestamp as the certificate serial number 

    Calendar calendar = Calendar.getInstance(); 
    calendar.setTime(startDate); 
    calendar.add(Calendar.YEAR, 1); // <-- 1 Yr validity 

    Date endDate = calendar.getTime(); 

    String signatureAlgorithm = "SHA256WithRSA"; // <-- Use appropriate signature algorithm based on your keyPair algorithm. 

    ContentSigner contentSigner = new JcaContentSignerBuilder(signatureAlgorithm).build(keyPair.getPrivate()); 

    JcaX509v3CertificateBuilder certBuilder = new JcaX509v3CertificateBuilder(dnName, certSerialNumber, startDate, endDate, dnName, keyPair.getPublic()); 

    // Extensions -------------------------- 

    // Basic Constraint 
    BasicConstraints basicConstraints = new BasicConstraints(true); // <-- true for CA, false for EndEntity 

    certBuilder.addExtension(new ASN1ObjectIdentifier("2.5.29.19"), true, basicConstraints); // Basic Constraints is usually marked as critical. 

    // ------------------------------------- 

    return new JcaX509CertificateConverter().setProvider(bcProvider).getCertificate(certBuilder.build(contentSigner)); 
} 
Verwandte Themen