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


Java PrivateKeyInfo.getInstance方法代碼示例

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


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

示例1: readPrivateKey

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
/** Read a PKCS#8 format private key. */
private static PrivateKey readPrivateKey(InputStream input)
throws IOException, GeneralSecurityException {
    try {
        byte[] buffer = new byte[4096];
        int size = input.read(buffer);
        byte[] bytes = Arrays.copyOf(buffer, size);
        /* Check to see if this is in an EncryptedPrivateKeyInfo structure. */
        PKCS8EncodedKeySpec spec = new PKCS8EncodedKeySpec(bytes);
        /*
         * Now it's in a PKCS#8 PrivateKeyInfo structure. Read its Algorithm
         * OID and use that to construct a KeyFactory.
         */
        ASN1InputStream bIn = new ASN1InputStream(new ByteArrayInputStream(spec.getEncoded()));
        PrivateKeyInfo pki = PrivateKeyInfo.getInstance(bIn.readObject());
        String algOid = pki.getPrivateKeyAlgorithm().getAlgorithm().getId();
        return KeyFactory.getInstance(algOid).generatePrivate(spec);
    } finally {
        input.close();
    }
}
 
開發者ID:bhb27,項目名稱:isu,代碼行數:22,代碼來源:ZipUtils.java

示例2: parseObject

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的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: decryptPrivateKeyInfo

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
public PrivateKeyInfo decryptPrivateKeyInfo(InputDecryptorProvider inputDecryptorProvider)
    throws PKCSException
{
    try
    {
        InputDecryptor decrytor = inputDecryptorProvider.get(encryptedPrivateKeyInfo.getEncryptionAlgorithm());

        ByteArrayInputStream encIn = new ByteArrayInputStream(encryptedPrivateKeyInfo.getEncryptedData());

        return PrivateKeyInfo.getInstance(Streams.readAll(decrytor.getInputStream(encIn)));
    }
    catch (Exception e)
    {
        throw new PKCSException("unable to read encrypted data: " + e.getMessage(), e);
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:17,代碼來源:PKCS8EncryptedPrivateKeyInfo.java

示例4: EncKeyWithID

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
private EncKeyWithID(ASN1Sequence seq)
{
    this.privKeyInfo = PrivateKeyInfo.getInstance(seq.getObjectAt(0));

    if (seq.size() > 1)
    {
        if (!(seq.getObjectAt(1) instanceof DERUTF8String))
        {
            this.identifier = GeneralName.getInstance(seq.getObjectAt(1));
        }
        else
        {
            this.identifier = (ASN1Encodable)seq.getObjectAt(1);
        }
    }
    else
    {
        this.identifier = null;
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:21,代碼來源:EncKeyWithID.java

示例5: engineGeneratePrivate

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
protected PrivateKey engineGeneratePrivate(
    KeySpec keySpec)
    throws InvalidKeySpecException
{
    if (keySpec instanceof PKCS8EncodedKeySpec)
    {
        try
        {
            PrivateKeyInfo info = PrivateKeyInfo.getInstance(((PKCS8EncodedKeySpec)keySpec).getEncoded());
            PrivateKey     key = BouncyCastleProvider.getPrivateKey(info);

            if (key != null)
            {
                return key;
            }

            throw new InvalidKeySpecException("no factory found for OID: " + info.getPrivateKeyAlgorithm().getAlgorithm());
        }
        catch (Exception e)
        {
            throw new InvalidKeySpecException(e.toString());
        }
    }

    throw new InvalidKeySpecException("Unknown KeySpec type: " + keySpec.getClass().getName());
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:27,代碼來源:KeyFactory.java

示例6: parseObject

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
public Object parseObject(PemObject obj)
    throws IOException
{
    try
    {
        return PrivateKeyInfo.getInstance(obj.getContent());
    }
    catch (Exception e)
    {
        throw new PEMException("problem parsing PRIVATE KEY: " + e.toString(), e);
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:13,代碼來源:PEMParser.java

示例7: init

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
private void init(PrivateKey key, ASN1ObjectIdentifier algorithm, Provider provider)
    throws NoSuchAlgorithmException
{
    this.key = PrivateKeyInfo.getInstance(key.getEncoded());
    this.encryptorBuilder = new JceOpenSSLPKCS8EncryptorBuilder(algorithm);

    encryptorBuilder.setProvider(provider);
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:9,代碼來源:PKCS8Generator.java

示例8: encrypt

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
PKCS8EncryptedPrivateKeyInfo encrypt(PrivateKey privateKey) {
    ParamUtil.requireNonNull("privateKey", privateKey);
    PrivateKeyInfo privateKeyInfo = PrivateKeyInfo.getInstance(privateKey.getEncoded());
    PKCS8EncryptedPrivateKeyInfoBuilder builder = new PKCS8EncryptedPrivateKeyInfoBuilder(
            privateKeyInfo);
    synchronized (encryptor) {
        return builder.build(encryptor);
    }
}
 
開發者ID:xipki,項目名稱:xitk,代碼行數:10,代碼來源:PrivateKeyCryptor.java

示例9: getPrivateKeyInfo

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
private static PrivateKeyInfo getPrivateKeyInfo(PrivateKey privateKey)
{
     try
     {
         return PrivateKeyInfo.getInstance(privateKey.getEncoded());
     }
     catch (Exception e)             // for a HSM getEncoded() may do anything...
     {
         return null;
     }
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:12,代碼來源:JcaPKIXIdentity.java

示例10: getPrivateKey

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
public ECPrivateKey getPrivateKey() throws IOException {
	ASN1Sequence pkSeq = null;
	pkSeq = (ASN1Sequence) ASN1Sequence.fromByteArray(pkBytes);
	
	PrivateKeyInfo pkInfo = PrivateKeyInfo.getInstance(pkSeq);
	ECPrivateKey ecpk = ECPrivateKey.getInstance(pkInfo.parsePrivateKey());
	return ecpk;
}
 
開發者ID:tsenger,項目名稱:animamea,代碼行數:9,代碼來源:CertificateProvider.java

示例11: testKeyConversion

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
private void testKeyConversion()
    throws Exception
{
    KeyPairGenerator kpGen = KeyPairGenerator.getInstance("ECDSA", "BC");

    kpGen.initialize(new ECGenParameterSpec("prime192v1"));

    KeyPair pair = kpGen.generateKeyPair();

    PublicKey pubKey = ECKeyUtil.publicToExplicitParameters(pair.getPublic(), "BC");

    SubjectPublicKeyInfo info = SubjectPublicKeyInfo.getInstance(ASN1Primitive.fromByteArray(pubKey.getEncoded()));
    X962Parameters params = X962Parameters.getInstance(info.getAlgorithmId().getParameters());

    if (params.isNamedCurve() || params.isImplicitlyCA())
    {
        fail("public key conversion to explicit failed");
    }

    if (!((ECPublicKey)pair.getPublic()).getW().equals(((ECPublicKey)pubKey).getW()))
    {
        fail("public key conversion check failed");
    }

    PrivateKey privKey = ECKeyUtil.privateToExplicitParameters(pair.getPrivate(), "BC");
    PrivateKeyInfo privInfo = PrivateKeyInfo.getInstance(ASN1Primitive.fromByteArray(privKey.getEncoded()));
    params = X962Parameters.getInstance(privInfo.getAlgorithmId().getParameters());

    if (params.isNamedCurve() || params.isImplicitlyCA())
    {
        fail("private key conversion to explicit failed");
    }

    if (!((ECPrivateKey)pair.getPrivate()).getS().equals(((ECPrivateKey)privKey).getS()))
    {
        fail("private key conversion check failed");
    }
}
 
開發者ID:NoYouShutup,項目名稱:CryptMeme,代碼行數:39,代碼來源:ECDSA5Test.java

示例12: testNamedCurveParameterPreservation

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
private void testNamedCurveParameterPreservation()
    throws Exception
{
    AlgorithmParameterSpec ecSpec = ECNamedCurveTable.getParameterSpec("secp256r1");
    KeyPairGenerator keygen = KeyPairGenerator.getInstance("EC", "BC");
    keygen.initialize(ecSpec, new ECRandom());

    KeyPair keys = keygen.generateKeyPair();

    PrivateKeyInfo priv1 = PrivateKeyInfo.getInstance(keys.getPrivate().getEncoded());
    SubjectPublicKeyInfo pub1 = SubjectPublicKeyInfo.getInstance(keys.getPublic().getEncoded());

    keygen = KeyPairGenerator.getInstance("EC", "BC");
    keygen.initialize(new ECGenParameterSpec("secp256r1"), new ECRandom());

    PrivateKeyInfo priv2 = PrivateKeyInfo.getInstance(keys.getPrivate().getEncoded());
    SubjectPublicKeyInfo pub2 = SubjectPublicKeyInfo.getInstance(keys.getPublic().getEncoded());

    if (!priv1.equals(priv2) || !pub1.equals(pub2))
    {
        fail("mismatch between alg param spec and ECGenParameterSpec");
    }

    if (!(priv2.getPrivateKeyAlgorithm().getParameters() instanceof ASN1ObjectIdentifier))
    {
        fail("OID not preserved in private key");
    }

    if (!(pub1.getAlgorithm().getParameters() instanceof ASN1ObjectIdentifier))
    {
        fail("OID not preserved in public key");
    }
}
 
開發者ID:NoYouShutup,項目名稱:CryptMeme,代碼行數:34,代碼來源:ECDSA5Test.java

示例13: JcaPKIArchiveControlBuilder

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
public JcaPKIArchiveControlBuilder(PrivateKey privateKey, GeneralName generalName)
{
    super(PrivateKeyInfo.getInstance(privateKey.getEncoded()), generalName);
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:5,代碼來源:JcaPKIArchiveControlBuilder.java

示例14: JcaPKCS8EncryptedPrivateKeyInfoBuilder

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
public JcaPKCS8EncryptedPrivateKeyInfoBuilder(PrivateKey privateKey)
{
     super(PrivateKeyInfo.getInstance(privateKey.getEncoded()));
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:5,代碼來源:JcaPKCS8EncryptedPrivateKeyInfoBuilder.java

示例15: JcaPKCS12SafeBagBuilder

import org.bouncycastle.asn1.pkcs.PrivateKeyInfo; //導入方法依賴的package包/類
public JcaPKCS12SafeBagBuilder(PrivateKey privateKey, OutputEncryptor encryptor)
{
    super(PrivateKeyInfo.getInstance(privateKey.getEncoded()), encryptor);
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:5,代碼來源:JcaPKCS12SafeBagBuilder.java


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