edu.vt.middleware.crypt.symmetric.Blowfish Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vt-crypt Show documentation
Show all versions of vt-crypt Show documentation
Library for performing common cryptographic operations
/*
$Id$
Copyright (C) 2007-2010 Virginia Tech.
All rights reserved.
SEE LICENSE FOR MORE INFORMATION
Author: Middleware Services
Email: [email protected]
Version: $Revision$
Updated: $Date$
*/
package edu.vt.middleware.crypt.symmetric;
/**
* Provider of symmetric encryption/decryption operations using Blowfish cipher.
*
* @author Middleware Services
* @version $Revision: 3 $
*/
public class Blowfish extends SymmetricAlgorithm
{
/** Algorithm name. */
public static final String ALGORITHM = "Blowfish";
/** Minimum key length in bits. */
public static final int MIN_KEY_LENGTH = 32;
/** Maximum key length in bits. */
public static final int MAX_KEY_LENGTH = 448;
/** Default key size for this algorithm in bits. */
public static final int DEFAULT_KEY_LENGTH = 128;
/** Available key lengths in bits. */
public static final int[] KEY_LENGTHS = new int[] {
448,
384,
320,
256,
192,
128,
64,
};
/** Number of bits in byte. */
private static final int BITS_IN_BYTE = 8;
/**
* Creates a default CAST5 symmetric encryption algorithm using CBC mode and
* PKCS5 padding.
*/
public Blowfish()
{
this(DEFAULT_MODE, DEFAULT_PADDING);
}
/**
* Creates a default Blowfish symmetric encryption algorithm using the given
* mode and padding style.
*
* @param mode Cipher mode name.
* @param padding Cipher padding style name.
*/
public Blowfish(final String mode, final String padding)
{
super(ALGORITHM, mode, padding);
}
/**
* Gets the default key length for this algorithm.
*
* @return Default key length in bits.
*/
public int getDefaultKeyLength()
{
return DEFAULT_KEY_LENGTH;
}
/** {@inheritDoc} */
public int[] getAllowedKeyLengths()
{
return KEY_LENGTHS;
}
/** {@inheritDoc} */
public int getMinKeyLength()
{
return MIN_KEY_LENGTH;
}
/** {@inheritDoc} */
public int getMaxKeyLength()
{
return MAX_KEY_LENGTH;
}
/** {@inheritDoc} */
public boolean isValidKeyLength(final int bitLength)
{
if (bitLength < MIN_KEY_LENGTH || bitLength > MAX_KEY_LENGTH) {
return false;
} else {
return bitLength % BITS_IN_BYTE == 0;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy