Package org.apache.commons.codec.digest
Class UnixCrypt
java.lang.Object
org.apache.commons.codec.digest.UnixCrypt
Unix crypt(3) algorithm implementation.
This class only implements the traditional 56 bit DES based algorithm. Please use Crypt.crypt() for a method that distinguishes between all the algorithms supported in the current glibc's crypt().
The Java implementation was taken from the JetSpeed Portal project (see org.apache.jetspeed.services.security.ldap.UnixCrypt).
This class is slightly incompatible if the given salt contains characters that are not part of the allowed range [a-zA-Z0-9./].
This class is immutable and thread-safe.
- Since:
- 1.7
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionstatic String
crypt
(byte[] original) Generates a crypt(3) compatible hash using the DES algorithm.static String
Generates a crypt(3) compatible hash using the DES algorithm.static String
Generates a crypt(3) compatible hash using the DES algorithm.static String
Generates a crypt(3) compatible hash using the DES algorithm.
-
Constructor Details
-
UnixCrypt
Deprecated.TODO Make private in 2.0.TODO Make private in 2.0.
-
-
Method Details
-
crypt
Generates a crypt(3) compatible hash using the DES algorithm.A salt is generated for you using
SecureRandom
.- Parameters:
original
- plaintext password- Returns:
- a 13 character string starting with the salt string
-
crypt
Generates a crypt(3) compatible hash using the DES algorithm.Using unspecified characters as salt results incompatible hash values.
- Parameters:
original
- plaintext passwordsalt
- a two character string drawn from [a-zA-Z0-9./]. The salt may be null, in which case a salt is generated for you usingB64.getRandomSalt(int)
.- Returns:
- a 13 character string starting with the salt string
- Throws:
IllegalArgumentException
- if the salt does not match the allowed pattern
-
crypt
Generates a crypt(3) compatible hash using the DES algorithm.A salt is generated for you using
SecureRandom
.- Parameters:
original
- plaintext password- Returns:
- a 13 character string starting with the salt string
-
crypt
Generates a crypt(3) compatible hash using the DES algorithm.- Parameters:
original
- plaintext passwordsalt
- a two character string drawn from [a-zA-Z0-9./]. The salt may be null, in which case a salt is generated for you usingSecureRandom
.- Returns:
- a 13 character string starting with the salt string
- Throws:
IllegalArgumentException
- if the salt does not match the allowed pattern
-