|
Bouncy Castle Cryptography Library 1.77.0 | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--org.bouncycastle.crypto.BufferedBlockCipher | +--org.bouncycastle.crypto.DefaultBufferedBlockCipher
A wrapper class that allows block ciphers to be used to process data in a piecemeal fashion. The BufferedBlockCipher outputs a block only when the buffer is full and more data is being added, or on a doFinal.
Note: in the case where the underlying cipher is either a CFB cipher or an OFB one the last block may not be a multiple of the block size. Use this class for construction rather than BufferedBlockCipher as BufferedBlockCipher will eventually turn into an interface.
Field Summary | |
protected byte[] |
buf
|
protected int |
bufOff
|
protected BlockCipher |
cipher
|
protected boolean |
forEncryption
|
protected MultiBlockCipher |
mbCipher
|
protected boolean |
partialBlockOkay
|
protected boolean |
pgpCFB
|
Constructor Summary | |
protected |
DefaultBufferedBlockCipher()
constructor for subclasses |
|
DefaultBufferedBlockCipher(BlockCipher cipher)
Create a buffered block cipher without padding. |
Method Summary | |
int |
doFinal(byte[] out,
int outOff)
Process the last block in the buffer. |
int |
getBlockSize()
return the blocksize for the underlying cipher. |
int |
getOutputSize(int length)
return the size of the output buffer required for an update plus a doFinal with an input of 'length' bytes. |
BlockCipher |
getUnderlyingCipher()
return the cipher this object wraps. |
int |
getUpdateOutputSize(int len)
return the size of the output buffer required for an update an input of len bytes. |
void |
init(boolean forEncryption,
CipherParameters params)
initialise the cipher. |
int |
processByte(byte in,
byte[] out,
int outOff)
process a single byte, producing an output block if necessary. |
int |
processBytes(byte[] in,
int inOff,
int len,
byte[] out,
int outOff)
process an array of bytes, producing output if necessary. |
void |
reset()
Reset the buffer and cipher. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
protected byte[] buf
protected int bufOff
protected boolean forEncryption
protected BlockCipher cipher
protected MultiBlockCipher mbCipher
protected boolean partialBlockOkay
protected boolean pgpCFB
Constructor Detail |
protected DefaultBufferedBlockCipher()
public DefaultBufferedBlockCipher(BlockCipher cipher)
cipher
- the underlying block cipher this buffering object wraps.Method Detail |
public BlockCipher getUnderlyingCipher()
getUnderlyingCipher
in class BufferedBlockCipher
public void init(boolean forEncryption, CipherParameters params) throws java.lang.IllegalArgumentException
init
in class BufferedBlockCipher
forEncryption
- if true the cipher is initialised for
encryption, if false for decryption.params
- the key and other data required by the cipher.java.lang.IllegalArgumentException
- if the params argument is
inappropriate.public int getBlockSize()
getBlockSize
in class BufferedBlockCipher
public int getUpdateOutputSize(int len)
getUpdateOutputSize
in class BufferedBlockCipher
len
- the length of the input.public int getOutputSize(int length)
getOutputSize
in class BufferedBlockCipher
length
- the length of the input.public int processByte(byte in, byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateException
processByte
in class BufferedBlockCipher
in
- the input byte.out
- the space for any output that might be produced.outOff
- the offset from which the output will be copied.DataLengthException
- if there isn't enough space in out.java.lang.IllegalStateException
- if the cipher isn't initialised.public int processBytes(byte[] in, int inOff, int len, byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateException
processBytes
in class BufferedBlockCipher
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.DataLengthException
- if there isn't enough space in out.java.lang.IllegalStateException
- if the cipher isn't initialised.public int doFinal(byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateException, InvalidCipherTextException
doFinal
in class BufferedBlockCipher
out
- the array the block currently being held is copied into.outOff
- the offset at which the copying starts.DataLengthException
- if there is insufficient space in out for
the output, or the input is not block size aligned and should be.java.lang.IllegalStateException
- if the underlying cipher is not
initialised.InvalidCipherTextException
- if padding is expected and not found.DataLengthException
- if the input is not block size
aligned.public void reset()
reset
in class BufferedBlockCipher
|
Bouncy Castle Cryptography Library 1.77.0 | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |