KEKRecipientInformationpublic class KEKRecipientInformation extends RecipientInformation the RecipientInfo class for a recipient who has been sent a message
encrypted using a secret key known to the other side. |
Fields Summary |
---|
private org.bouncycastle.asn1.cms.KEKRecipientInfo | _info | private org.bouncycastle.asn1.x509.AlgorithmIdentifier | _encAlg |
Methods Summary |
---|
public CMSTypedStream | getContentStream(java.security.Key key, java.lang.String prov)decrypt the content and return an input stream.
return getContentStream(key, CMSUtils.getProvider(prov));
| public CMSTypedStream | getContentStream(java.security.Key key, java.security.Provider prov)decrypt the content and return an input stream.
try
{
byte[] encryptedKey = _info.getEncryptedKey().getOctets();
Cipher keyCipher = Cipher.getInstance(_keyEncAlg.getObjectId().getId(), prov);
keyCipher.init(Cipher.UNWRAP_MODE, key);
AlgorithmIdentifier aid = _encAlg;
String alg = aid.getObjectId().getId();
Key sKey = keyCipher.unwrap(
encryptedKey, alg, Cipher.SECRET_KEY);
return getContentFromSessionKey(sKey, prov);
}
catch (NoSuchAlgorithmException e)
{
throw new CMSException("can't find algorithm.", e);
}
catch (InvalidKeyException e)
{
throw new CMSException("key invalid in message.", e);
}
catch (NoSuchPaddingException e)
{
throw new CMSException("required padding not supported.", e);
}
|
|