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


Java CMSEnvelopedDataStreamGenerator類代碼示例

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


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

示例1: writeTo

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
@Override
public void writeTo(EnvelopedOutput out, Class<?> type, Type genericType, Annotation[] annotations, MediaType mediaType, MultivaluedMap<String, Object> headers, OutputStream os) throws IOException, WebApplicationException {
    try {
        headers.putSingle("Content-Disposition", "attachment; filename=\"smime.p7m\"");
        headers.putSingle("Content-Type", "application/pkcs7-mime; smime-type=enveloped-data; name=\"smime.p7m\"");
        headers.putSingle("Content-Transfer-Encoding", "base64");

        OutputEncryptor encryptor = new JceCMSContentEncryptorBuilder(CMSAlgorithm.DES_EDE3_CBC)
                .setProvider("BC")
                .build();
        if (out.getCertificate() == null) {
            throw new NullPointerException("The certificate object was not set.");
        }
        JceKeyTransRecipientInfoGenerator infoGenerator = new JceKeyTransRecipientInfoGenerator(out.getCertificate());
        infoGenerator.setProvider("BC");
        CMSEnvelopedDataStreamGenerator generator = new CMSEnvelopedDataStreamGenerator();
        generator.addRecipientInfoGenerator(infoGenerator);


        MimeBodyPart message = createBodyPart(providers, out);

        final ByteArrayOutputStream baos = new ByteArrayOutputStream();
        final OutputStream encrypted = generator.open(baos, encryptor);

        message.writeTo(encrypted);
        encrypted.close();
        byte[] bytes = baos.toByteArray();
        String str = Base64.encodeBytes(bytes, Base64.DO_BREAK_LINES);
        os.write(str.getBytes());
    } catch (Exception e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:gini,項目名稱:jersey-smime,代碼行數:34,代碼來源:EnvelopedWriter.java

示例2: testKeyTransAES128Throughput

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransAES128Throughput()
    throws Exception
{
    byte[] data = new byte[40001];

    for (int i = 0; i != data.length; i++)
    {
        data[i] = (byte)(i & 0xff);
    }

    //
    // buffered
    //
    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.setBufferSize(BUFFER_SIZE);

    edGen.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(_reciCert).setProvider(BC));

    ByteArrayOutputStream bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(bOut, new JceCMSContentEncryptorBuilder(CMSAlgorithm.AES128_CBC).setProvider(BC).build());

    for (int i = 0; i != data.length; i++)
    {
        out.write(data[i]);
    }

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());
    RecipientInformationStore  recipients = ep.getRecipientInfos();
    Collection                 c = recipients.getRecipients();
    Iterator                   it = c.iterator();

    if (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());

        CMSTypedStream recData = recipient.getContentStream(new JceKeyTransEnvelopedRecipient(_reciKP.getPrivate()).setProvider(BC));

        InputStream           dataStream = recData.getContentStream();
        ByteArrayOutputStream dataOut = new ByteArrayOutputStream();
        int                   len;
        byte[]                buf = new byte[BUFFER_SIZE];
        int                   count = 0;

        while (count != 10 && (len = dataStream.read(buf)) > 0)
        {
            assertEquals(buf.length, len);

            dataOut.write(buf);
            count++;
        }

        len = dataStream.read(buf);
        dataOut.write(buf, 0, len);

        assertEquals(true, Arrays.equals(data, dataOut.toByteArray()));
    }
    else
    {
        fail("recipient not found.");
    }
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:68,代碼來源:NewEnvelopedDataStreamTest.java

示例3: testKeyTransAES128Throughput

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransAES128Throughput()
    throws Exception
{
    byte[] data = new byte[40001];
    
    for (int i = 0; i != data.length; i++)
    {
        data[i] = (byte)(i & 0xff);
    }
    
    //
    // buffered
    //
    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.setBufferSize(BUFFER_SIZE);
    
    edGen.addKeyTransRecipient(_reciCert);

    ByteArrayOutputStream bOut = new ByteArrayOutputStream();
    
    OutputStream out = edGen.open(bOut, CMSEnvelopedDataGenerator.AES128_CBC, BC);

    for (int i = 0; i != data.length; i++)
    {
        out.write(data[i]);
    }
    
    out.close();
    
    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());
    RecipientInformationStore  recipients = ep.getRecipientInfos();
    Collection                 c = recipients.getRecipients();
    Iterator                   it = c.iterator();
    
    if (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());
        
        CMSTypedStream recData = recipient.getContentStream(_reciKP.getPrivate(), BC);
        
        InputStream           dataStream = recData.getContentStream();
        ByteArrayOutputStream dataOut = new ByteArrayOutputStream();
        int                   len;
        byte[]                buf = new byte[BUFFER_SIZE];
        int                   count = 0;
        
        while (count != 10 && (len = dataStream.read(buf)) > 0)
        {
            assertEquals(buf.length, len);
            
            dataOut.write(buf);
            count++;
        }
        
        len = dataStream.read(buf);
        dataOut.write(buf, 0, len);
        
        assertEquals(true, Arrays.equals(data, dataOut.toByteArray()));
    }
    else
    {
        fail("recipient not found.");
    }
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:68,代碼來源:EnvelopedDataStreamTest.java

示例4: testKeyTransAES128Der

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransAES128Der()
    throws Exception
{
    byte[] data = new byte[2000];

    for (int i = 0; i != 2000; i++)
    {
        data[i] = (byte)(i & 0xff);
    }

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(_reciCert).setProvider(BC));

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut, new JceCMSContentEncryptorBuilder(CMSAlgorithm.AES128_CBC).setProvider(BC).build());

    for (int i = 0; i != 2000; i++)
    {
        out.write(data[i]);
    }

    out.close();

    // convert to DER
    ASN1InputStream aIn = new ASN1InputStream(bOut.toByteArray());

    bOut.reset();

    DEROutputStream dOut = new DEROutputStream(bOut);

    dOut.writeObject(aIn.readObject());

    verifyData(bOut, CMSEnvelopedDataGenerator.AES128_CBC, data);
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:38,代碼來源:NewEnvelopedDataStreamTest.java

示例5: testKeyTransAES128

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransAES128()
    throws Exception
{
    byte[]          data     = "WallaWallaWashington".getBytes();

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(_reciCert).setProvider(BC));

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut, new JceCMSContentEncryptorBuilder(CMSAlgorithm.AES128_CBC).setProvider(BC).build());

    out.write(data);

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.AES128_CBC);

    Collection  c = recipients.getRecipients();
    Iterator    it = c.iterator();

    while (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());

        CMSTypedStream recData = recipient.getContentStream(new JceKeyTransEnvelopedRecipient(_reciKP.getPrivate()).setProvider(BC));

        assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));
    }

    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:41,代碼來源:NewEnvelopedDataStreamTest.java

示例6: testECKeyAgree

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testECKeyAgree()
    throws Exception
{
    byte[] data = Hex.decode("504b492d4320434d5320456e76656c6f706564446174612053616d706c65");

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    JceKeyAgreeRecipientInfoGenerator recipientGenerator = new JceKeyAgreeRecipientInfoGenerator(CMSAlgorithm.ECDH_SHA1KDF, _origEcKP.getPrivate(), _origEcKP.getPublic(), CMSAlgorithm.AES128_WRAP).setProvider(BC);

    recipientGenerator.addRecipient(_reciEcCert);

    edGen.addRecipientInfoGenerator(recipientGenerator);
    
    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut,
                            new JceCMSContentEncryptorBuilder(CMSAlgorithm.AES128_CBC).setProvider(BC).build());
    out.write(data);

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.AES128_CBC);

    RecipientId                recSel = new JceKeyAgreeRecipientId(_reciEcCert);

    RecipientInformation       recipient = recipients.get(recSel);

    CMSTypedStream recData = recipient.getContentStream(new JceKeyAgreeEnvelopedRecipient(_reciEcKP.getPrivate()).setProvider(BC));

    assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));

    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:39,代碼來源:NewEnvelopedDataStreamTest.java

示例7: testKeyTransAES128Der

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransAES128Der()
    throws Exception
{
    byte[] data = new byte[2000];
    
    for (int i = 0; i != 2000; i++)
    {
        data[i] = (byte)(i & 0xff);
    }

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addKeyTransRecipient(_reciCert);

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();
    
    OutputStream out = edGen.open(
                            bOut, CMSEnvelopedDataGenerator.AES128_CBC, BC);

    for (int i = 0; i != 2000; i++)
    {
        out.write(data[i]);
    }
    
    out.close();
    
    // convert to DER
    ASN1InputStream aIn = new ASN1InputStream(bOut.toByteArray());
    
    bOut.reset();
    
    DEROutputStream dOut = new DEROutputStream(bOut);
    
    dOut.writeObject(aIn.readObject());
  
    verifyData(bOut, CMSEnvelopedDataGenerator.AES128_CBC, data);
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:38,代碼來源:EnvelopedDataStreamTest.java

示例8: testKeyTransAES128

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransAES128()
    throws Exception
{
    byte[]          data     = "WallaWallaWashington".getBytes();
    
    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addKeyTransRecipient(_reciCert);

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();
    
    OutputStream out = edGen.open(
                            bOut, CMSEnvelopedDataGenerator.AES128_CBC, BC);

    out.write(data);
    
    out.close();
    
    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.AES128_CBC);
    
    Collection  c = recipients.getRecipients();
    Iterator    it = c.iterator();
    
    while (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());
        
        CMSTypedStream recData = recipient.getContentStream(_reciKP.getPrivate(), BC);
        
        assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));
    }
    
    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:41,代碼來源:EnvelopedDataStreamTest.java

示例9: testECKeyAgree

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testECKeyAgree()
    throws Exception
{
    byte[] data = Hex.decode("504b492d4320434d5320456e76656c6f706564446174612053616d706c65");

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addKeyAgreementRecipient(CMSEnvelopedDataGenerator.ECDH_SHA1KDF, _origEcKP.getPrivate(), _origEcKP.getPublic(), _reciEcCert, CMSEnvelopedDataGenerator.AES128_WRAP, BC);

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut,
                            CMSEnvelopedDataGenerator.AES128_CBC, BC);
    out.write(data);

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.AES128_CBC);

    RecipientId                recSel = new JceKeyAgreeRecipientId(_reciEcCert);

    RecipientInformation       recipient = recipients.get(recSel);

    CMSTypedStream recData = recipient.getContentStream(_reciEcKP.getPrivate(), BC);

    assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));

    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:35,代碼來源:EnvelopedDataStreamTest.java

示例10: testUnprotectedAttributes

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testUnprotectedAttributes()
    throws Exception
{
    byte[]          data     = "WallaWallaWashington".getBytes();

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(_reciCert).setProvider(BC));

    Hashtable attrs = new Hashtable();

    attrs.put(PKCSObjectIdentifiers.id_aa_contentHint, new Attribute(PKCSObjectIdentifiers.id_aa_contentHint, new DERSet(new DERUTF8String("Hint"))));
    attrs.put(PKCSObjectIdentifiers.id_aa_receiptRequest, new Attribute(PKCSObjectIdentifiers.id_aa_receiptRequest, new DERSet(new DERUTF8String("Request"))));

    AttributeTable attrTable = new AttributeTable(attrs);

    edGen.setUnprotectedAttributeGenerator(new SimpleAttributeTableGenerator(attrTable));

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut, new JceCMSContentEncryptorBuilder(CMSAlgorithm.AES128_CBC).setProvider(BC).build());

    out.write(data);

    out.close();

    CMSEnvelopedDataParser ed = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ed.getRecipientInfos();

    Collection  c = recipients.getRecipients();

    assertEquals(1, c.size());

    Iterator    it = c.iterator();

    while (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());

        byte[] recData = recipient.getContent(new JceKeyTransEnvelopedRecipient(_reciKP.getPrivate()).setProvider(BC));

        assertEquals(true, Arrays.equals(data, recData));
    }

    attrTable = ed.getUnprotectedAttributes();

    assertEquals(attrs.size(), 2);

    assertEquals(new DERUTF8String("Hint"), attrTable.get(PKCSObjectIdentifiers.id_aa_contentHint).getAttrValues().getObjectAt(0));
    assertEquals(new DERUTF8String("Request"), attrTable.get(PKCSObjectIdentifiers.id_aa_receiptRequest).getAttrValues().getObjectAt(0));

}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:57,代碼來源:NewEnvelopedDataStreamTest.java

示例11: testKeyTransAES128AndOriginatorInfo

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransAES128AndOriginatorInfo()
    throws Exception
{
    byte[]          data     = "WallaWallaWashington".getBytes();

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    X509CertificateHolder origCert = new X509CertificateHolder(_origCert.getEncoded());

    edGen.setOriginatorInfo(new OriginatorInfoGenerator(origCert).generate());

    edGen.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(_reciCert).setProvider(BC));

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut, new JceCMSContentEncryptorBuilder(CMSAlgorithm.AES128_CBC).setProvider(BC).build());

    out.write(data);

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    assertTrue(ep.getOriginatorInfo().getCertificates().getMatches(null).contains(origCert));

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.AES128_CBC);

    Collection  c = recipients.getRecipients();
    Iterator    it = c.iterator();

    while (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());

        CMSTypedStream recData = recipient.getContentStream(new JceKeyTransEnvelopedRecipient(_reciKP.getPrivate()).setProvider(BC));

        assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));
    }

    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:47,代碼來源:NewEnvelopedDataStreamTest.java

示例12: testKeyTransCAST5SunJCE

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransCAST5SunJCE()
    throws Exception
{
    if (Security.getProvider("SunJCE") == null)
    {
        return;
    }

    String version = System.getProperty("java.version");
    if (version.startsWith("1.4") || version.startsWith("1.3"))
    {
        return;
    }

    byte[]          data     = "WallaWallaWashington".getBytes();

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(_reciCert).setProvider("SunJCE"));

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut, new JceCMSContentEncryptorBuilder(CMSAlgorithm.CAST5_CBC).setProvider(BC).build());

    out.write(data);

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.CAST5_CBC);

    Collection  c = recipients.getRecipients();
    Iterator    it = c.iterator();

    while (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());

        CMSTypedStream recData = recipient.getContentStream(new JceKeyTransEnvelopedRecipient(_reciKP.getPrivate()).setProvider("SunJCE").setContentProvider(BC));

        assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));
    }

    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:52,代碼來源:NewEnvelopedDataStreamTest.java

示例13: testAESKEK

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testAESKEK()
    throws Exception
{
    byte[]    data = "WallaWallaWashington".getBytes();
    SecretKey kek  = CMSTestUtil.makeAES192Key();

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    byte[]  kekId = new byte[] { 1, 2, 3, 4, 5 };

    edGen.addRecipientInfoGenerator(new JceKEKRecipientInfoGenerator(kekId, kek).setProvider(BC));

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut,
                            new JceCMSContentEncryptorBuilder(CMSAlgorithm.DES_EDE3_CBC).setProvider(BC).build());
    out.write(data);

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.DES_EDE3_CBC);

    Collection  c = recipients.getRecipients();
    Iterator    it = c.iterator();

    while (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), "2.16.840.1.101.3.4.1.25");

        CMSTypedStream recData = recipient.getContentStream(new JceKEKEnvelopedRecipient(kek).setProvider(BC));

        assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));
    }

    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:44,代碼來源:NewEnvelopedDataStreamTest.java

示例14: testTwoAESKEK

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testTwoAESKEK()
    throws Exception
{
    byte[]    data = "WallaWallaWashington".getBytes();
    SecretKey kek1  = CMSTestUtil.makeAES192Key();
    SecretKey kek2  = CMSTestUtil.makeAES192Key();

    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    byte[]  kekId1 = new byte[] { 1, 2, 3, 4, 5 };
    byte[]  kekId2 = new byte[] { 5, 4, 3, 2, 1 };

    edGen.addRecipientInfoGenerator(new JceKEKRecipientInfoGenerator(kekId1, kek1).setProvider(BC));
    edGen.addRecipientInfoGenerator(new JceKEKRecipientInfoGenerator(kekId2, kek2).setProvider(BC));

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();

    OutputStream out = edGen.open(
                            bOut,
                            new JceCMSContentEncryptorBuilder(CMSAlgorithm.DES_EDE3_CBC).setProvider(BC).build());
    out.write(data);

    out.close();

    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.DES_EDE3_CBC);

    RecipientId                recSel = new KEKRecipientId(kekId2);

    RecipientInformation       recipient = recipients.get(recSel);

    assertEquals(recipient.getKeyEncryptionAlgOID(), "2.16.840.1.101.3.4.1.25");

    CMSTypedStream recData = recipient.getContentStream(new JceKEKEnvelopedRecipient(kek2).setProvider(BC));

    assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));

    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:43,代碼來源:NewEnvelopedDataStreamTest.java

示例15: testKeyTransCAST5SunJCE

import org.bouncycastle.cms.CMSEnvelopedDataStreamGenerator; //導入依賴的package包/類
public void testKeyTransCAST5SunJCE()
    throws Exception
{
    if (Security.getProvider("SunJCE") == null)
    {
        return;
    }
    
    String version = System.getProperty("java.version");
    if (version.startsWith("1.4") || version.startsWith("1.3"))
    {
        return;
    }
    
    byte[]          data     = "WallaWallaWashington".getBytes();
    
    CMSEnvelopedDataStreamGenerator edGen = new CMSEnvelopedDataStreamGenerator();

    edGen.addKeyTransRecipient(_reciCert);

    ByteArrayOutputStream  bOut = new ByteArrayOutputStream();
    
    OutputStream out = edGen.open(
                            bOut, CMSEnvelopedDataGenerator.CAST5_CBC, "SunJCE");

    out.write(data);
    
    out.close();
    
    CMSEnvelopedDataParser     ep = new CMSEnvelopedDataParser(bOut.toByteArray());

    RecipientInformationStore  recipients = ep.getRecipientInfos();

    assertEquals(ep.getEncryptionAlgOID(), CMSEnvelopedDataGenerator.CAST5_CBC);
    
    Collection  c = recipients.getRecipients();
    Iterator    it = c.iterator();
    
    while (it.hasNext())
    {
        RecipientInformation   recipient = (RecipientInformation)it.next();

        assertEquals(recipient.getKeyEncryptionAlgOID(), PKCSObjectIdentifiers.rsaEncryption.getId());
        
        CMSTypedStream recData = recipient.getContentStream(_reciKP.getPrivate(), "SunJCE");
        
        assertEquals(true, Arrays.equals(data, CMSTestUtil.streamToByteArray(recData.getContentStream())));
    }
    
    ep.close();
}
 
開發者ID:credentials,項目名稱:irma_future_id,代碼行數:52,代碼來源:EnvelopedDataStreamTest.java


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