當前位置: 首頁>>代碼示例>>Java>>正文


Java X509CertificateHolder.getSubject方法代碼示例

本文整理匯總了Java中org.bouncycastle.cert.X509CertificateHolder.getSubject方法的典型用法代碼示例。如果您正苦於以下問題:Java X509CertificateHolder.getSubject方法的具體用法?Java X509CertificateHolder.getSubject怎麽用?Java X509CertificateHolder.getSubject使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.bouncycastle.cert.X509CertificateHolder的用法示例。


在下文中一共展示了X509CertificateHolder.getSubject方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: newCert

import org.bouncycastle.cert.X509CertificateHolder; //導入方法依賴的package包/類
public static Certificate newCert(String parentCertFile, String keyFile, String host) {
    try {
        Date before = Date.from(Instant.now());
        Date after = Date.from(Year.now().plus(3, ChronoUnit.YEARS).atDay(1).atStartOfDay(ZoneId.systemDefault()).toInstant());

        X509CertificateHolder parent = readPemFromFile(parentCertFile);
        PEMKeyPair pemKeyPair = readPemFromFile(keyFile);
        KeyPair keyPair = new JcaPEMKeyConverter()
                .setProvider(PROVIDER)
                .getKeyPair(pemKeyPair);

        X509v3CertificateBuilder x509 = new JcaX509v3CertificateBuilder(
                parent.getSubject(),
                new BigInteger(64, new SecureRandom()),
                before,
                after,
                new X500Name("CN=" + host),
                keyPair.getPublic());

        ContentSigner signer = new JcaContentSignerBuilder("SHA256WithRSAEncryption")
                .build(keyPair.getPrivate());

        JcaX509CertificateConverter x509CertificateConverter = new JcaX509CertificateConverter()
                .setProvider(PROVIDER);

        return new Certificate(
                keyPair,
                x509CertificateConverter.getCertificate(x509.build(signer)),
                x509CertificateConverter.getCertificate(parent));
    } catch (Exception e) {
        throw new IllegalStateException(e);
    }
}
 
開發者ID:chhsiao90,項目名稱:nitmproxy,代碼行數:34,代碼來源:CertUtil.java

示例2: getEmailFromCert

import org.bouncycastle.cert.X509CertificateHolder; //導入方法依賴的package包/類
/**
 * Extract email addresses from a certificate
 * 
 * @param cert the X509 certificate holder
 * @return a List of all email addresses found
 * @throws CertificateException
 */
private static List<String> getEmailFromCert(X509CertificateHolder cert)
        throws CertificateException {
    List<String> res = new ArrayList<>();

    X500Name subject = cert.getSubject();
    for (RDN emails : subject.getRDNs(BCStyle.EmailAddress)) {
        for (AttributeTypeAndValue emailAttr: emails.getTypesAndValues()) {
            log.debug("Add email from RDN: " + IETFUtils.valueToString(emailAttr.getValue()));
            res.add(IETFUtils.valueToString(emailAttr.getValue()));
        }
    }

    Extension subjectAlternativeNames = cert
            .getExtension(Extension.subjectAlternativeName);
    if (subjectAlternativeNames != null) {
        for (GeneralName name : GeneralNames.getInstance(
                subjectAlternativeNames.getParsedValue()).getNames()) {
            if (name.getTagNo() == GeneralName.rfc822Name) {
                String email = IETFUtils.valueToString(name.getName());
                log.debug("Add email from subjectAlternativeName: " + email);
                res.add(email);
            }
        }
    }

    return res;
}
 
開發者ID:johrstrom,項目名稱:cloud-meter,代碼行數:35,代碼來源:SMIMEAssertion.java

示例3: testGenerateWithPrincipal

import org.bouncycastle.cert.X509CertificateHolder; //導入方法依賴的package包/類
private void testGenerateWithPrincipal()
    throws Exception
{
    X509CertificateHolder             iCert = new X509CertificateHolder(signCert);
    
    //
    // a sample key pair.
    //
    RSAKeyParameters pubKey = new RSAKeyParameters(false,
        new BigInteger("b4a7e46170574f16a97082b22be58b6a2a629798419be12872a4bdba626cfae9900f76abfb12139dce5de56564fab2b6543165a040c606887420e33d91ed7ed7", 16),
        new BigInteger("11", 16));

    //
    // set up the keys
    //
    X509v2AttributeCertificateBuilder gen = new X509v2AttributeCertificateBuilder(
        new AttributeCertificateHolder(iCert.getSubject()),
        new AttributeCertificateIssuer(new X500Name("cn=test")),
        BigInteger.ONE,
        new Date(System.currentTimeMillis() - 50000),
        new Date(System.currentTimeMillis() + 50000));
    
    // the actual attributes
    GeneralName roleName = new GeneralName(GeneralName.rfc822Name, "DAU123456789");
    ASN1EncodableVector roleSyntax = new ASN1EncodableVector();
    roleSyntax.add(roleName);

    // roleSyntax OID: 2.5.24.72

    gen.addAttribute(new ASN1ObjectIdentifier("2.5.24.72"), new DERSequence(roleSyntax));

    AlgorithmIdentifier sigAlgId = new DefaultSignatureAlgorithmIdentifierFinder().find("SHA1WithRSAEncryption");
    AlgorithmIdentifier digAlgId = new DefaultDigestAlgorithmIdentifierFinder().find(sigAlgId);

    ContentSigner sigGen = new BcRSAContentSignerBuilder(sigAlgId, digAlgId).build(RSA_PRIVATE_KEY);

    X509AttributeCertificateHolder aCert = gen.build(sigGen);
    
    if (!aCert.isValidOn(new Date()))
    {
        fail("certificate invalid");
    }
    
    if (!aCert.isSignatureValid(new BcRSAContentVerifierProviderBuilder(new DefaultDigestAlgorithmIdentifierFinder()).build(pubKey)))
    {
        fail("certificate signature not valid");
    }
    
    AttributeCertificateHolder holder = aCert.getHolder();
    
    if (holder.getEntityNames() == null)
    {
        fail("entity names not set when expected");
    }
    
    if (holder.getSerialNumber() != null)
    {
        fail("holder serial number found when none expected");
    }

    if (holder.getIssuer() != null)
    {
        fail("holder issuer found when none expected");
    }
    
    if (!holder.match(iCert))
    {
        fail("generated holder not matching holder certificate");
    }
    
    X509CertificateHolder             sCert = new X509CertificateHolder(holderCertWithBaseCertificateID);
    
    if (holder.match(sCert))
    {
        fail("principal generated holder matching wrong certificate");
    }

    equalityAndHashCodeTest(aCert, aCert.getEncoded());
}
 
開發者ID:ttt43ttt,項目名稱:gwt-crypto,代碼行數:80,代碼來源:AttrCertTest.java

示例4: createAttrCert

import org.bouncycastle.cert.X509CertificateHolder; //導入方法依賴的package包/類
private X509AttributeCertificateHolder createAttrCert() throws Exception
{
    X509CertificateHolder iCertHolder = new X509CertificateHolder(holderCert);
    //
    // a sample key pair.
    //
    // RSAPublicKeySpec pubKeySpec = new RSAPublicKeySpec(
    // new BigInteger(
    // "b4a7e46170574f16a97082b22be58b6a2a629798419be12872a4bdba626cfae9900f76abfb12139dce5de56564fab2b6543165a040c606887420e33d91ed7ed7",
    // 16), new BigInteger("11", 16));

    //
    // set up the keys
    //
    X509v2AttributeCertificateBuilder gen = new X509v2AttributeCertificateBuilder(
            new AttributeCertificateHolder(iCertHolder.getSubject()),
            new AttributeCertificateIssuer(new X500Name("cn=test")),
            BigInteger.valueOf(1),
            new Date(System.currentTimeMillis() - 50000),
            new Date(System.currentTimeMillis() + 50000));

    // the actual attributes
    GeneralName roleName = new GeneralName(GeneralName.rfc822Name,
        "[email protected]");
    ASN1EncodableVector roleSyntax = new ASN1EncodableVector();
    roleSyntax.add(roleName);

    // roleSyntax OID: 2.5.24.72
    gen.addAttribute(new ASN1ObjectIdentifier("2.5.24.72"), new DERSequence(roleSyntax));

    AlgorithmIdentifier sigAlgId = new DefaultSignatureAlgorithmIdentifierFinder().find("SHA1WithRSAEncryption");
    AlgorithmIdentifier digAlgId = new DefaultDigestAlgorithmIdentifierFinder().find(sigAlgId);

    ContentSigner sigGen = new BcRSAContentSignerBuilder(sigAlgId, digAlgId).build(RSA_PRIVATE_KEY);

    Target targetName = new Target(Target.targetName, new GeneralName(GeneralName.dNSName,
        "www.test.com"));

    Target targetGroup = new Target(Target.targetGroup, new GeneralName(
        GeneralName.directoryName, "o=Test, ou=Test"));
    Target[] targets = new Target[2];
    targets[0] = targetName;
    targets[1] = targetGroup;
    TargetInformation targetInformation = new TargetInformation(targets);

    gen.addExtension(X509Extension.targetInformation, true, targetInformation);

    return gen.build(sigGen);
}
 
開發者ID:ttt43ttt,項目名稱:gwt-crypto,代碼行數:50,代碼來源:AttrCertSelectorTest.java

示例5: BcX509v3CertificateBuilder

import org.bouncycastle.cert.X509CertificateHolder; //導入方法依賴的package包/類
/**
 * Initialise the builder using the subject from the passed in issuerCert as the issuer, as well as
 * passing through and converting the other objects provided.
 *
 * @param issuerCert holder for certificate who's subject is the issuer of the certificate we are building.
 * @param serial the serial number for the certificate.
 * @param notBefore date before which the certificate is not valid.
 * @param notAfter date after which the certificate is not valid.
 * @param subject principal representing the subject of this certificate.
 * @param publicKey the public key to be associated with the certificate.
 */
public BcX509v3CertificateBuilder(X509CertificateHolder issuerCert, BigInteger serial, Date notBefore, Date notAfter, X500Name subject, AsymmetricKeyParameter publicKey)
    throws IOException
{
    super(issuerCert.getSubject(), serial, notBefore, notAfter, subject, SubjectPublicKeyInfoFactory.createSubjectPublicKeyInfo(publicKey));
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:17,代碼來源:BcX509v3CertificateBuilder.java


注:本文中的org.bouncycastle.cert.X509CertificateHolder.getSubject方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。