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


Java PemObject類代碼示例

本文整理匯總了Java中org.bouncycastle.util.io.pem.PemObject的典型用法代碼示例。如果您正苦於以下問題:Java PemObject類的具體用法?Java PemObject怎麽用?Java PemObject使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


PemObject類屬於org.bouncycastle.util.io.pem包,在下文中一共展示了PemObject類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: createPrivateKeyFromPemFile

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
private static PrivateKey createPrivateKeyFromPemFile(final String keyFileName) throws IOException, InvalidKeySpecException, NoSuchAlgorithmException 
{
	// Loads a privte key from the specified key file name
    final PemReader pemReader = new PemReader(new FileReader(keyFileName));
    final PemObject pemObject = pemReader.readPemObject();
    final byte[] pemContent = pemObject.getContent();
    pemReader.close();
    final PKCS8EncodedKeySpec encodedKeySpec = new PKCS8EncodedKeySpec(pemContent);
    final KeyFactory keyFactory = getKeyFactoryInstance();
    final PrivateKey privateKey = keyFactory.generatePrivate(encodedKeySpec);
    return privateKey;
}
 
開發者ID:PacktPublishing,項目名稱:MQTT-Essentials-A-Lightweight-IoT-Protocol,代碼行數:13,代碼來源:SecurityHelper.java

示例2: parseObject

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
public Object parseObject(PemObject obj)
    throws IOException
{
    try
    {
        PrivateKeyInfo info = PrivateKeyInfo.getInstance(ASN1Primitive.fromByteArray(obj.getContent()));
        PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(obj.getContent());

        KeyFactory keyFact = KeyFactory.getInstance(info.getPrivateKeyAlgorithm().getAlgorithm().getId(), provider);

        return keyFact.generatePrivate(keySpec);
    }
    catch (Exception e)
    {
        throw new PEMException("problem parsing PRIVATE KEY: " + e.toString(), e);
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:18,代碼來源:PEMReader.java

示例3: convert

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
public static ByteArrayOutputStream convert(final ByteArrayOutputStream baos) {
	try (ByteArrayOutputStream autoCloseableBaos = baos;
			ByteArrayInputStream bais = new ByteArrayInputStream(autoCloseableBaos.toByteArray());
			Reader reader = new InputStreamReader(bais);
			PemReader pemReader = new PemReader(reader)) {
		PemObject pemObject = pemReader.readPemObject();
		if (pemObject == null) {
			throw new DSSException("Unable to read PEM Object");
		}
		byte[] binaries = pemObject.getContent();
		ByteArrayOutputStream os = new ByteArrayOutputStream();
		os.write(binaries, 0, binaries.length);
		return os;
	} catch (IOException e) {
		throw new DSSException("Unable to convert the CRL to DER", e);
	}
}
 
開發者ID:esig,項目名稱:dss,代碼行數:18,代碼來源:PemToDerConverter.java

示例4: readObject

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
public Object readObject()
    throws IOException
{
    PemObject obj = readPemObject();

    if (obj != null)
    {
        String type = obj.getType();
        if (parsers.containsKey(type))
        {
            return ((PemObjectParser)parsers.get(type)).parseObject(obj);
        }
        else
        {
            throw new IOException("unrecognised object: " + type);
        }
    }

    return null;
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:21,代碼來源:PEMReader.java

示例5: generate

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
public PemObject generate()
    throws PemGenerationException
{
    try
    {
        if (encryptorBuilder != null)
        {
            outputEncryptor = encryptorBuilder.build();
        }
    }
    catch (OperatorCreationException e)
    {
        throw new PemGenerationException("unable to create operator: " + e.getMessage(), e);
    }

    if (outputEncryptor != null)
    {
        return generate(key, outputEncryptor);
    }
    else
    {
        return generate(key, null);
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:25,代碼來源:PKCS8Generator.java

示例6: generateCA

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
protected void generateCA() throws NoSuchProviderException, NoSuchAlgorithmException, IOException, OperatorCreationException {
    KeyPair pair = generateKey();
    LocalDateTime startDate = LocalDate.now().atStartOfDay();

    X509v3CertificateBuilder builder= new X509v3CertificateBuilder(
            new X500Name("CN=ca"),
            new BigInteger("0"),
            Date.from(startDate.atZone(ZoneId.systemDefault()).toInstant()),
            Date.from(startDate.plusDays(3650).atZone(ZoneId.systemDefault()).toInstant()),
            new X500Name("CN=ca"),
            SubjectPublicKeyInfo.getInstance(pair.getPublic().getEncoded()));
    JcaContentSignerBuilder csBuilder= new JcaContentSignerBuilder("SHA512WithRSAEncryption");
    ContentSigner signer = csBuilder.build(pair.getPrivate());
    X509CertificateHolder holder = builder.build(signer);
    try (PemWriter writer = new PemWriter(new FileWriter(pemPath.toFile()))) {
        writer.writeObject(new PemObject("CERTIFICATE", holder.toASN1Structure().getEncoded()));
    }
    try (PemWriter writer = new PemWriter(new FileWriter(keyPath.toFile()))) {
        writer.writeObject(new PemObject("PRIVATE KEY", pair.getPrivate().getEncoded()));
    }
}
 
開發者ID:kawasima,項目名稱:occupy-pub,代碼行數:22,代碼來源:CertificationAuthority.java

示例7: convertToPresentation

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
@Override
public String convertToPresentation(String value, Class<? extends String> targetType, Locale locale) throws ConversionException {
    if (value == null) {
        return null;
    } else {
        try {
            final CertificateFactory certFactory = CertificateFactory.getInstance("X.509");
            final InputStream in = new ByteArrayInputStream(Base64.decodeBase64(value));
            final Certificate certificate = certFactory.generateCertificate(in);
            final StringWriter stringWriter = new StringWriter();
            final PemWriter pemWriter = new PemWriter(stringWriter);
            final PemObject pemObject = new PemObject("CERTIFICATE", certificate.getEncoded());
            pemWriter.writeObject(pemObject);
            pemWriter.flush();
            return stringWriter.toString();
        } catch (final Exception e) {
            throw new ConversionException("Error generating X509 certificate from database byte array.", e);
        }
    }
}
 
開發者ID:bubblecloud,項目名稱:ilves,代碼行數:21,代碼來源:CertificateConverter.java

示例8: parseChain

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
public static List<Certificate> parseChain(final String chain) throws IOException, CertificateException {
    Preconditions.checkNotNull(chain);

    final List<Certificate> certs = new ArrayList<Certificate>();
    try(final PemReader pemReader = new PemReader(new StringReader(chain));)
    {
        final PemObject pemObject = pemReader.readPemObject();
        final CertificateFactory certificateFactory = CertificateFactory.getInstance("X509");
        final ByteArrayInputStream bais = new ByteArrayInputStream(pemObject.getContent());

        for (final Certificate cert : certificateFactory.generateCertificates(bais)) {
            if (cert instanceof X509Certificate) {
                certs.add(cert);
            }
        }
        if (certs.isEmpty()) {
            throw new IllegalStateException("Unable to decode certificate chain");
        }
    }
    return certs;
}
 
開發者ID:apache,項目名稱:cloudstack,代碼行數:22,代碼來源:CertificateHelper.java

示例9: generateCertificateUsingCsr

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
private Certificate generateCertificateUsingCsr(final String csr, final List<String> domainNames, final List<String> ipAddresses, final int validityDays) throws NoSuchAlgorithmException, InvalidKeyException, NoSuchProviderException, CertificateException, SignatureException, IOException, OperatorCreationException {
    PemObject pemObject = null;

    try {
        final PemReader pemReader = new PemReader(new StringReader(csr));
        pemObject = pemReader.readPemObject();
    } catch (IOException e) {
        LOG.error("Failed to read provided CSR string as a PEM object", e);
    }

    if (pemObject == null) {
        throw new CloudRuntimeException("Unable to read/process CSR: " + csr);
    }

    final PKCS10CertificationRequest request = new PKCS10CertificationRequest(pemObject.getContent());

    final String subject = request.getCertificationRequestInfo().getSubject().toString();
    final X509Certificate clientCertificate = CertUtils.generateV3Certificate(
            caCertificate, caKeyPair, request.getPublicKey(),
            subject, CAManager.CertSignatureAlgorithm.value(),
            validityDays, domainNames, ipAddresses);
    return new Certificate(clientCertificate, null, Collections.singletonList(caCertificate));
}
 
開發者ID:apache,項目名稱:cloudstack,代碼行數:24,代碼來源:RootCAProvider.java

示例10: parse

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
/**
 * Parse a PemObject. Currently only supports  <code>CERTIFICATE</code> / <code>X.509 CERTIFICATE</code> types
 *
 * @param obj
 * 		a PemObject with a type and with contents
 *
 * @return a parsed object (or null if the input is null)
 *
 * @throws GeneralSecurityException
 * 		if there is a parsing problem
 * @throws IllegalArgumentException
 * 		if the PemObject cannot be recognised
 */
public static Object parse(final PemObject obj) throws GeneralSecurityException
{
	if (obj == null)
	{
		return null;
	}
	else if (obj.getType() == null)
	{
		throw new RuntimeException("Encountered invalid PemObject with null type: " + obj);
	}
	else if (obj.getType().equalsIgnoreCase("CERTIFICATE") || obj.getType().equalsIgnoreCase("X.509 CERTIFICATE"))
	{
		return parseX509Certificate(obj);
	}
	else
	{
		throw new IllegalArgumentException("Unknown PEM contents: encountered unsupported entry of type " +
		                                   obj.getType() +
		                                   " (expected CERTIFICATE or X.509 CERTIFICATE)");
	}
}
 
開發者ID:petergeneric,項目名稱:stdlib,代碼行數:35,代碼來源:PEMHelper.java

示例11: parseObject

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
/**
 * Reads in a X509Certificate.
 *
 * @return the X509Certificate
 * @throws IOException if an I/O error occured
 */
public Object parseObject(PemObject obj)
    throws IOException
{
    ByteArrayInputStream bIn = new ByteArrayInputStream(obj.getContent());

    try
    {
        CertificateFactory certFact
            = CertificateFactory.getInstance("X.509", provider);

        return certFact.generateCertificate(bIn);
    }
    catch (Exception e)
    {
        throw new PEMException("problem parsing cert: " + e.toString(), e);
    }
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:24,代碼來源:PEMReader.java

示例12: loadPrivateKeyResource

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
static AsymmetricKeyParameter loadPrivateKeyResource(String resource)
    throws IOException
{

    PemObject pem = loadPemResource(resource);
    if (pem.getType().endsWith("RSA PRIVATE KEY"))
    {
        RSAPrivateKey rsa = RSAPrivateKey.getInstance(pem.getContent());
        return new RSAPrivateCrtKeyParameters(rsa.getModulus(), rsa.getPublicExponent(),
            rsa.getPrivateExponent(), rsa.getPrime1(), rsa.getPrime2(), rsa.getExponent1(),
            rsa.getExponent2(), rsa.getCoefficient());
    }
    if (pem.getType().endsWith("PRIVATE KEY"))
    {
        return PrivateKeyFactory.createKey(pem.getContent());
    }
    throw new IllegalArgumentException("'resource' doesn't specify a valid private key");
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:19,代碼來源:TlsTestUtils.java

示例13: getSocketFactoryFromPEM

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
private SSLSocketFactory getSocketFactoryFromPEM(String filePath) throws Exception {
    Security.addProvider(new BouncyCastleProvider());

    PEMParser pemParser = new PEMParser(new FileReader(getConfigFilename(filePath)));
    pemParser.readObject();
    PemObject pemObject = pemParser.readPemObject();
    pemParser.close();

    X509CertificateHolder holder = new X509CertificateHolder(pemObject.getContent());
    X509Certificate bc = new JcaX509CertificateConverter().setProvider("BC")
            .getCertificate(holder);

    KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
    keyStore.load(null, null);
    keyStore.setCertificateEntry("ca", bc);

    TrustManager trustManager = TrustManagerUtils.getDefaultTrustManager(keyStore);
    SSLContext sslContext = SSLContextUtils.createSSLContext("TLS", null, trustManager);

    return sslContext.getSocketFactory();
}
 
開發者ID:Appdynamics,項目名稱:mongo-monitoring-extension,代碼行數:22,代碼來源:MongoDBMonitor.java

示例14: parseObject

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
/**
 * Reads in a X509Certificate.
 *
 * @return the X509Certificate
 * @throws java.io.IOException if an I/O error occured
 */
public Object parseObject(PemObject obj)
    throws IOException
{
    try
    {
        return new X509CertificateHolder(obj.getContent());
    }
    catch (Exception e)
    {
        throw new PEMException("problem parsing cert: " + e.toString(), e);
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:19,代碼來源:PEMParser.java

示例15: generate

import org.bouncycastle.util.io.pem.PemObject; //導入依賴的package包/類
public PemObject generate()
    throws PemGenerationException
{
    try
    {
        return createPemObject(obj);
    }
    catch (IOException e)
    {
        throw new PemGenerationException("encoding exception: " + e.getMessage(), e);
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:13,代碼來源:MiscPEMGenerator.java


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