| 
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectorg.gudy.bouncycastle.crypto.BufferedBlockCipher
public class BufferedBlockCipher
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.
| Field Summary | |
|---|---|
protected  byte[] | 
buf
 | 
protected  int | 
bufOff
 | 
protected  BlockCipher | 
cipher
 | 
protected  boolean | 
forEncryption
 | 
protected  boolean | 
partialBlockOkay
 | 
protected  boolean | 
pgpCFB
 | 
| Constructor Summary | |
|---|---|
protected  | 
BufferedBlockCipher()
constructor for subclasses  | 
  | 
BufferedBlockCipher(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 len)
return the size of the output buffer required for an update plus a doFinal with an input of len 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 neccessary.  | 
 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 boolean partialBlockOkay
protected boolean pgpCFB
| Constructor Detail | 
|---|
protected BufferedBlockCipher()
public BufferedBlockCipher(BlockCipher cipher)
cipher - the underlying block cipher this buffering object wraps.padded - true if the buffer should add, or remove, pad bytes,
 false otherwise.| Method Detail | 
|---|
public BlockCipher getUnderlyingCipher()
public void init(boolean forEncryption,
                 CipherParameters params)
          throws IllegalArgumentException
forEncryption - if true the cipher is initialised for
  encryption, if false for decryption.param - the key and other data required by the cipher.
IllegalArgumentException - if the params argument is
 inappropriate.public int getBlockSize()
public int getUpdateOutputSize(int len)
len - the length of the input.
public int getOutputSize(int len)
len - the length of the input.
public int processByte(byte in,
                       byte[] out,
                       int outOff)
                throws DataLengthException,
                       IllegalStateException
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.
IllegalStateException - if the cipher isn't initialised.
public int processBytes(byte[] in,
                        int inOff,
                        int len,
                        byte[] out,
                        int outOff)
                 throws DataLengthException,
                        IllegalStateException
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.
IllegalStateException - if the cipher isn't initialised.
public int doFinal(byte[] out,
                   int outOff)
            throws DataLengthException,
                   IllegalStateException,
                   InvalidCipherTextException
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.
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()
  | 
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||