Class PaddedBufferedMultiBlockCipher
java.lang.Object
org.bouncycastle.crypto.internal.DefaultBufferedMultiBlockCipher
org.bouncycastle.crypto.internal.paddings.PaddedBufferedMultiBlockCipher
- All Implemented Interfaces:
BufferedBlockCipher
A wrapper class that allows multi-block ciphers to be used to process data in
a piecemeal fashion with padding. The PaddedBufferedMultiBlockCipher
outputs a block only when the buffer is full and more data is being added,
or on a doFinal (unless the current block in the buffer is a pad block).
The default padding mechanism used is the one outlined in PKCS5/PKCS7.
-
Field Summary
Fields inherited from class DefaultBufferedMultiBlockCipher
blockSize, buf, bufOff, cipher, forEncryption, partialBlockOkay, pgpCFB -
Constructor Summary
ConstructorsConstructorDescriptionPaddedBufferedMultiBlockCipher(MultiBlockCipher cipher, BlockCipherPadding padding) Create a buffered block cipher with the desired padding. -
Method Summary
Modifier and TypeMethodDescriptionintdoFinal(byte[] out, int outOff) Process the last block in the buffer.intgetOutputSize(int len) return the minimum size of the output buffer required for an update plus a doFinal with an input of len bytes.intgetUpdateOutputSize(int len) return the size of the output buffer required for an update an input of len bytes.voidinit(boolean forEncryption, CipherParameters params) initialise the cipher.intprocessBytes(byte[] in, int inOff, int len, byte[] out, int outOff) process an array of bytes, producing output if necessary.Methods inherited from class DefaultBufferedMultiBlockCipher
getBlockSize, getUnderlyingCipher, reset, toString
-
Constructor Details
-
PaddedBufferedMultiBlockCipher
Create a buffered block cipher with the desired padding.- Parameters:
cipher- the underlying block cipher this buffering object wraps.padding- the padding type.
-
-
Method Details
-
init
initialise the cipher.- Specified by:
initin interfaceBufferedBlockCipher- Overrides:
initin classDefaultBufferedMultiBlockCipher- Parameters:
forEncryption- if true the cipher is initialised for encryption, if false for decryption.params- the key and other data required by the cipher.- Throws:
IllegalArgumentException- if the params argument is inappropriate.
-
getOutputSize
public int getOutputSize(int len) return the minimum size of the output buffer required for an update plus a doFinal with an input of len bytes.- Specified by:
getOutputSizein interfaceBufferedBlockCipher- Overrides:
getOutputSizein classDefaultBufferedMultiBlockCipher- Parameters:
len- the length of the input.- Returns:
- the space required to accommodate a call to update and doFinal with len bytes of input.
-
getUpdateOutputSize
public int getUpdateOutputSize(int len) return the size of the output buffer required for an update an input of len bytes.- Specified by:
getUpdateOutputSizein interfaceBufferedBlockCipher- Overrides:
getUpdateOutputSizein classDefaultBufferedMultiBlockCipher- Parameters:
len- the length of the input.- Returns:
- the space required to accommodate a call to update with len bytes of input.
-
processBytes
public int processBytes(byte[] in, int inOff, int len, byte[] out, int outOff) throws DataLengthException, IllegalStateException process an array of bytes, producing output if necessary.- Specified by:
processBytesin interfaceBufferedBlockCipher- Overrides:
processBytesin classDefaultBufferedMultiBlockCipher- Parameters:
in- the input byte array.inOff- the offset at which the input data starts.len- the number of bytes to be copied out of the input array.out- the space for any output that might be produced.outOff- the offset from which the output will be copied.- Returns:
- the number of output bytes copied to out.
- Throws:
DataLengthException- if there isn't enough space in out.IllegalStateException- if the cipher isn't initialised.
-
doFinal
public int doFinal(byte[] out, int outOff) throws DataLengthException, IllegalStateException, InvalidCipherTextException Process the last block in the buffer. If the buffer is currently full and padding needs to be added a call to doFinal will produce 2 * getBlockSize() bytes.- Specified by:
doFinalin interfaceBufferedBlockCipher- Overrides:
doFinalin classDefaultBufferedMultiBlockCipher- Parameters:
out- the array the block currently being held is copied into.outOff- the offset at which the copying starts.- Returns:
- the number of output bytes copied to out.
- Throws:
DataLengthException- if there is insufficient space in out for the output or we are decrypting and the input is not block size aligned.IllegalStateException- if the underlying cipher is not initialised.InvalidCipherTextException- if padding is expected and not found.
-