Interface StreamCipher
- All Known Subinterfaces:
CFBModeCipher, CTRModeCipher, SkippingStreamCipher
- All Known Implementing Classes:
CFBBlockCipher, ChaCha7539Engine, ChaChaEngine, G3413CFBBlockCipher, G3413CTRBlockCipher, G3413OFBBlockCipher, GCFBBlockCipher, GOFBBlockCipher, Grain128Engine, Grainv1Engine, HC128Engine, HC256Engine, ISAACEngine, KCTRBlockCipher, OFBBlockCipher, RC4Engine, Salsa20Engine, SICBlockCipher, StreamBlockCipher, VMPCEngine, VMPCKSA3Engine, XSalsa20Engine, Zuc128CoreEngine, Zuc128Engine, Zuc256CoreEngine, Zuc256Engine
public interface StreamCipher
the interface stream ciphers conform to.
-
Method Summary
Modifier and TypeMethodDescriptionReturn the name of the algorithm the cipher implements.voidinit(boolean forEncryption, CipherParameters params) Initialise the cipher.intprocessBytes(byte[] in, int inOff, int len, byte[] out, int outOff) process a block of bytes from in putting the result into out.voidreset()reset the cipher.bytereturnByte(byte in) encrypt/decrypt a single byte returning the result.
-
Method Details
-
init
Initialise the cipher.- 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.
-
getAlgorithmName
String getAlgorithmName()Return the name of the algorithm the cipher implements.- Returns:
- the name of the algorithm the cipher implements.
-
returnByte
byte returnByte(byte in) encrypt/decrypt a single byte returning the result.- Parameters:
in- the byte to be processed.- Returns:
- the result of processing the input byte.
-
processBytes
process a block of bytes from in putting the result into out.- Parameters:
in- the input byte array.inOff- the offset into the in array where the data to be processed starts.len- the number of bytes to be processed.out- the output buffer the processed bytes go into.outOff- the offset into the output byte array the processed data starts at.- Returns:
- the number of bytes produced - should always be len.
- Throws:
DataLengthException- if the output buffer is too small.
-
reset
void reset()reset the cipher. This leaves it in the same state it was at after the last init (if there was one).
-