public class NISTCTSBlockCipher extends DefaultBufferedBlockCipher
This class implements the NIST version as documented in "Addendum to NIST SP 800-38A, Recommendation for Block Cipher Modes of Operation: Three Variants of Ciphertext Stealing for CBC Mode"
Modifier and Type | Field and Description |
---|---|
static int |
CS1 |
static int |
CS2 |
static int |
CS3 |
buf, bufOff, cipher, forEncryption, mbCipher, partialBlockOkay, pgpCFB
Constructor and Description |
---|
NISTCTSBlockCipher(int type,
BlockCipher cipher)
Create a buffered block cipher that uses NIST Cipher Text Stealing
|
Modifier and Type | Method and Description |
---|---|
int |
doFinal(byte[] out,
int outOff)
Process the last block in the buffer.
|
int |
getOutputSize(int len)
return the size of the output buffer required for an update plus a
doFinal with an input of len bytes.
|
int |
getUpdateOutputSize(int len)
return the size of the output buffer required for an update
an input of len bytes.
|
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.
|
getBlockSize, getUnderlyingCipher, init, reset
public static final int CS1
public static final int CS2
public static final int CS3
public NISTCTSBlockCipher(int type, BlockCipher cipher)
type
- type of CTS mode (CS1, CS2, or CS3)cipher
- the underlying block cipher used to create the CBC block cipher this cipher uses..public int getUpdateOutputSize(int len)
getUpdateOutputSize
in class DefaultBufferedBlockCipher
len
- the length of the input.public int getOutputSize(int len)
getOutputSize
in class DefaultBufferedBlockCipher
len
- the length of the input.public int processByte(byte in, byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateException
processByte
in class DefaultBufferedBlockCipher
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 DefaultBufferedBlockCipher
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 DefaultBufferedBlockCipher
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.java.lang.IllegalStateException
- if the underlying cipher is not
initialised.InvalidCipherTextException
- if cipher text decrypts wrongly (in
case the exception will never get thrown).