des, des_random_key, des_set_key, des_set_key_checked,
des_set_key_unchecked, des_set_odd_parity,
des_ecb_encrypt, des_ecb2_encrypt, des_ecb3_encrypt,
des_ncbc_encrypt, des_cfb_encrypt, des_ofb_encrypt,
des_pcbc_encrypt, des_cfb64_encrypt, des_ofb64_encrypt,
des_xcbc_encrypt, des_ede2_cbc_encrypt,
des_ede2_cfb64_encrypt, des_ede2_ofb64_encrypt,
des_ede3_cbc_encrypt, des_ede3_cbcm_encrypt,
des_ede3_cfb64_encrypt, des_ede3_ofb64_encrypt,
des_read_password, des_read_2passwords,
des_read_pw_string, des_cbc_cksum, des_string_to_2keys,
des_fcrypt, des_enc_read, des_enc_write - DES encryption
#include <openssl/des.h>
void des_random_key(
des_cblock *ret ); int des_set_key(
const_des_cblock *key,
des_key_schedule schedule ); int des_key_sched(
const_des_cblock *key,
des_key_schedule schedule ); int
des_set_key_checked(
const_des_cblock *key,
des_key_schedule schedule ); void
des_set_key_unchecked(
const_des_cblock *key,
des_key_schedule schedule ); void des_set_odd_parity(
des_cblock *key ); int des_is_weak_key(
const_des_cblock *key ); void des_ecb_encrypt(
const_des_cblock *input,
des_cblock *output,
des_key_schedule ks,
int enc ); void des_ecb2_encrypt(
const_des_cblock *input,
des_cblock *output,
des_key_schedule ks1,
des_key_schedule ks2,
int enc ); void des_ecb3_encrypt(
const_des_cblock *input,
, des_cblock *output,
des_key_schedule ks1,
des_key_schedule ks2,
des_key_schedule ks3,
int enc ); void des_ncbc_encrypt(
const unsigned char *input,
unsigned char *output,
long length,
des_key_schedule schedule,
des_cblock *ivec,
int enc ); void des_cfb_encrypt(
const unsigned char *in,
unsigned char *out,
int numbits,
long length,
des_key_schedule schedule,
des_cblock *ivec,
int enc ); void des_ofb_encrypt(
const unsigned char *in,
unsigned char *out,
int numbits,
long length,
des_key_schedule schedule,
des_cblock *ivec ); void des_pcbc_encrypt(
const unsigned char *input,
nsigned char *output,
u,
long length,
des_key_schedule schedule,
des_cblock *ivec,
int enc ); void des_cfb64_encrypt(
const unsigned char *in,
unsigned char *out,
long length,
des_key_schedule schedule,
des_cblock *ivec,
int *num,
int enc ); void des_ofb64_encrypt(
const unsigned char *in,
unsigned char *out,
long length,
des_key_schedule schedule,
des_cblock *ivec,
int *num ); void des_xcbc_encrypt(
const unsigned char *input,
unsigned char *output,
long length,
des_key_schedule schedule,
des_cblock *ivec,
const_des_cblock *inw,
const_des_cblock *outw,
int enc ); void des_ede2_cbc_encrypt(
const unsigned char *input,
unsigned char *output,
long length,
des_key_schedule ks1,
des_key_schedule ks2,
des_cblock *ivec,
int enc ); void des_ede2_cfb64_encrypt(
const unsigned char *in,
unsigned char *out,
long length,
des_key_schedule ks1,
des_key_schedule ks2,
des_cblock *ivec,
int *num,
int enc ); void des_ede2_ofb64_encrypt(
const unsigned char *in,
unsigned char *out,
long length,
des_key_schedule ks1,
des_key_schedule ks2,
des_cblock *ivec,
int *num ); void des_ede3_cbc_encrypt(
const unsigned char *input,
unsigned char *output,
long length,
des_key_schedule ks1,
des_key_schedule ks2,
des_key_schedule ks3,
des_cblock *ivec,
int enc ); void des_ede3_cbcm_encrypt(
const unsigned char *in,
unsigned char *out,
long length,
des_key_schedule ks1,
des_key_schedule ks2,
des_key_schedule ks3,
des_cblock *ivec1,
des_cblock *ivec2,
int enc ); void des_ede3_cfb64_encrypt(
const unsigned char *in,
unsigned char *out,
long length,
des_key_schedule ks1,
des_key_schedule ks2,
des_key_schedule ks3,
des_cblock *ivec,
int *num,
int enc ); void des_ede3_ofb64_encrypt(
const unsigned char *in,
unsigned char *out,
long length,
des_key_schedule ks1,
des_key_schedule ks2,
des_key_schedule ks3,
des_cblock *ivec,
int *num ); int des_read_password(
des_cblock *key,
const char *prompt,
int verify ); int des_read_2passwords(
des_cblock *key1,
des_cblock *key2,
const char *prompt,
int verify ); int des_read_pw_string(
char *buf,
int length,
const char *prompt,
int verify ); DES_LONG des_cbc_cksum(
const unsigned char *input,
des_cblock *output,
long length,
des_key_schedule schedule,
const_des_cblock *ivec ); DES_LONG des_quad_cksum(
const unsigned char *input,
des_cblock output[],
long length,
int out_count,
des_cblock *seed ); void des_string_to_key(
const char *str,
des_cblock *key ); void des_string_to_2keys(
const char *str,
des_cblock *key1,
des_cblock *key2 ); char *des_fcrypt(
const char *buf,
const char *salt,
char *ret ); char *des_crypt(
const char *buf,
const char *salt ); char *crypt(
const char *buf,
const char *salt ); int des_enc_read(
int fd,
void *buf,
int len,
des_key_schedule sched,
des_cblock *iv ); int des_enc_write(
int fd,
const void *buf,
int len,
des_key_schedule sched,
des_cblock *iv );
This library contains a fast implementation of the DES
encryption algorithm.
There are two phases to the use of DES encryption. The
first is the generation of a des_key_schedule from a key;
the second is the actual encryption. A DES key is of type
des_cblock. This type consists of 8 bytes with odd parity.
The least significant bit in each byte is the parity
bit. The key schedule is an expanded form of the key; it
is used to speed the encryption process.
The des_random_key() generates a random key. The PRNG
must be seeded prior to using this function (see
rand_ssl(3); for backward compatibility the des_random_seed()
function is available as well). If the PRNG
could not generate a secure key, 0 is returned. In earlier
versions of the library, des_random_key() did not
generate secure keys.
Before a DES key can be used, it must be converted into
the architecture dependent des_key_schedule via the
des_set_key_checked() or des_set_key_unchecked() functions.
The des_set_key_checked() function will check that the key
passed is of odd parity and is not a weak or semi-weak
key. If the parity is wrong, then -1 is returned. If the
key is a weak key, then -2 is returned. If an error is
returned, the key schedule is not generated.
The des_set_key() function (called des_key_sched() in the
MIT library) works like des_set_key_checked() if the
des_check_key flag is non-zero; otherwise, it works like
des_set_key_unchecked(). These functions are available
for compatibility; we recommend you use a function that
does not depend on a global variable.
The des_set_odd_parity() function (called
des_fixup_key_parity() in the MIT library) sets the parity
of the passed key to odd.
The des_is_weak_key() function returns 1 is the passed key
is a weak key, 0 if it is ok. The probability that a randomly
generated key is weak is 1/2^52.
The following routines mostly operate on an input and output
stream of des_cblock: The des_ecb_encrypt() function
is the basic DES encryption routine that encrypts or
decrypts a single 8-byte des_cblock in electronic code
book (ECB) mode. It always transforms the input data,
pointed to by input, into the output data, pointed to by
the output argument. If the encrypt argument is non-zero
(DES_ENCRYPT), the input (cleartext) is encrypted in to
the output (ciphertext) using the key_schedule specified
by the schedule argument, previously set via des_set_key.
If encrypt is zero (DES_DECRYPT), the input (now ciphertext)
is decrypted into the output (now cleartext). Input
and output may overlap. The des_ecb_encrypt() function
does not return a value. The des_ecb3_encrypt() function
encrypts and decrypts the input block by using three-key
Triple-DES encryption in ECB mode. This involves encrypting
the input with ks1, decrypting with the key schedule
ks2, and then encrypting with ks3. This routine greatly
reduces the chances of brute force breaking of DES and has
the advantage if ks1, ks2 and ks3 are the same. It is
equivalent to encryption using ECB mode and ks1 as the
key. The des_ecb2_encrypt() macro is provided to perform
two-key Triple-DES encryption by using ks1 for the final
encryption. The des_ncbc_encrypt() function encrypts and
decrypts using the cipher-block-chaining (CBC) mode of
DES. If the encrypt argument is non-zero, the routine
cipher-block-chain encrypts the cleartext data pointed to
by the input argument into the ciphertext pointed to by
the output argument, using the key schedule provided by
the schedule argument, and initialization vector provided
by the ivec argument. If the length argument is not an
integral multiple of eight bytes, the last block is copied
to a temporary area and zero filled. The output is always
an integral multiple of eight bytes. The
des_xcbc_encrypt() function is RSA's DESX mode of DES. It
uses inw and outw to whiten the encryption. The inw and
outw are secret (unlike the iv) and are part of the key.
So the key is sort of 24 bytes. This is much better than
CBC DES. The des_ede3_cbc_encrypt() function implements
outer triple CBC DES encryption with three keys. This
means that each DES operation inside the CBC mode is
really an C=E(ks3,D(ks2,E(ks1,M))). This mode is used by
SSL. The des_ede2_cbc_encrypt() macro implements two-key
Triple-DES by reusing ks1 for the final encryption.
C=E(ks1,D(ks2,E(ks1,M))). This form of Triple-DES is used
by the RSAREF library. The des_pcbc_encrypt() function
encrypts and decrypts using the propagating cipher block
chaining mode used by Kerberos v4. Its parameters are the
same as des_ncbc_encrypt(). The des_cfb_encrypt() function
encrypts and decrypts using cipher feedback mode.
This method takes an array of characters as input and outputs
and array of characters. It does not require any
padding to 8 character groups. The ivec variable is
changed and the new changed value needs to be passed to
the next call to this function. Since this function runs
a complete DES ECB encryption per numbits, this function
is only suggested for use when sending small numbers of
characters. The des_cfb64_encrypt() function implements
CFB mode of DES with 64-bit feedback. This is useful
because this routine will allow you to encrypt an arbitrary
number of bytes, no 8-byte padding. Each call to
this routine will encrypt the input bytes to output and
then update ivec and num. The num shows where you are
through ivec. The des_ede3_cfb64_encrypt() and
des_ede2_cfb64_encrypt() functions are the same as the
des_cfb64_encrypt() function except that Triple-DES is
used. The des_ofb_encrypt() function encrypts using output
feedback mode. This method takes an array of characters
as input and outputs and array of characters. It
does not require any padding to 8-character groups. The
ivec variable is changed and the new changed value needs
to be passed to the next call to this function. Since
this function runs a complete DES ECB encryption per
numbits, we recommend using this function only when sending
small numbers of characters. The des_ofb64_encrypt()
function is the same as the des_cfb64_encrypt() function
using Output Feed Back mode. The des_ede3_ofb64_encrypt()
and des_ede2_ofb64_encrypt() functions are the same as
des_ofb64_encrypt() using Triple-DES.
The following functions are included in the DES library
for compatibility with the MIT Kerberos library. The
des_read_pw_string() function is also available under the
name EVP_read_pw_string(). The des_read_pw_string() function
writes the string specified by prompt to standard
output, turns echo off and reads in input string from the
terminal. The string is returned in buf, which must have
space for at least length bytes. If verify is set, the
user is asked for the password twice. Unless the two
copies match, an error is returned. A return code of -1
indicates a system error, 1 failure due to use interaction,
and 0 is success. The des_read_password() function
does the same and converts the password to a DES key by
calling des_string_to_key(); the des_read_2password()
function operates in the same way as des_read_password()
except that it generates two keys by using the
des_string_to_2key() function. The des_string_to_key()
function is available for backward compatibility with the
MIT library. New applications should use a cryptographic
hash function. The same applies for the
des_string_to_2key() function. The des_cbc_cksum() function
produces an 8-byte checksum based on the input stream
(via CBC encryption). The last 4 bytes of the checksum
are returned and the complete 8 bytes are placed in output.
This function is used by Kerberos v4. Other applications
should use EVP_DigestInit() etc. instead. The
des_quad_cksum() function is a Kerberos v4 function. It
returns a 4-byte checksum from the input bytes. The algorithm
can be iterated over the input, depending on
out_count, 1, 2, 3 or 4 times. If output is non-NULL, the
8 bytes generated by each pass are written into output.
The following are DES-based transformations: The
des_fcrypt() function is a fast version of the Unix
crypt() function. This version takes only a small amount
of space relative to other fast crypt() implementations.
This is different from the normal crypt in that the third
parameter is the buffer that the return value is written
into. It needs to be at least 14 bytes long. This function
is thread safe, unlike the normal crypt. The
des_crypt() function is a faster replacement for the normal
system crypt(). This function calls des_fcrypt() with
a static array passed as the third parameter. This emulates
the normal non-thread safe semantics of crypt().
The des_enc_write() function writes len bytes to file
descriptor fd from buffer buf. The data is encrypted via
pcbc_encrypt (default) using sched for the key and iv as a
starting vector. The actual data send down fd consists of
4 bytes (in network byte order) containing the length of
the following encrypted data. The encrypted data then
follows, padded with random data out to a multiple of 8
bytes. The des_enc_read() function is used to read len
bytes from file descriptor fd into buffer buf. The data
being read from fd is assumed to have come from
des_enc_write() and is decrypted using sched for the key
schedule and iv for the initial vector.
Note
The data format used by des_enc_write() and
des_enc_read() has a cryptographic weakness: When
asked to write more than MAXWRITE bytes,
des_enc_write() will split the data into several
chunks that are all encrypted using the same IV.
We do not recommend using these functions unless
you are sure you know what you do. They cannot
handle non-blocking sockets. The des_enc_read()
function uses an internal state and cannot be used
on multiple files. The des_rw_mode specifies the
encryption mode to use with the des_enc_read() and
des_end_write() functions. If it is set to
DES_PCBC_MODE (the default), des_pcbc_encrypt is
used. If it is set to DES_CBC_MODE,
des_cbc_encrypt is used.
Single-key DES is insecure due to its short key size. ECB
mode is not suitable for most applications; see
des_modes(7).
The evp(3) library provides higher-level encryption functions.
The des_3cbc_encrypt() function is flawed and must not be
used in applications.
The des_cbc_encrypt() function does not modify ivec; use
the des_ncbc_encrypt() function instead.
The des_cfb_encrypt() and des_ofb_encrypt() functions
operate on input of 8 bits. What this means is that if you
set numbits to 12, and length to 2, the first 12 bits will
come from the first input byte and the low half of the
second input byte. The second 12 bits will have the low 8
bits taken from the 3rd input byte and the top 4 bits
taken from the fourth input byte. The same holds for output.
This function has been implemented this way because
most people will be using a multiple of 8.
The des_read_pw_string() function is the most machine/OS
dependent function and normally generates the most problems
when porting this code.
The des library was written to be source code compatible
with the MIT Kerberos library. It conforms to ANSI X3.106.
The des_cbc_cksum(), des_cbc_encrypt(), des_ecb_encrypt(),
des_is_weak_key(), des_key_sched(), des_pcbc_encrypt(),
des_quad_cksum(), des_random_key(), des_read_password(),
and des_string_to_key() functions are available in the MIT
Kerberos library; the des_check_key_parity(),
des_fixup_key_parity(), and des_is_weak_key() functions
are available in newer versions of that library.
The des_set_key_checked() and des_set_key_unchecked()
functions were added in OpenSSL 0.9.5.
The des_generate_random_block(), des_init_random_number_generator(),
des_new_random_key(), des_set_random_generator_seed(),
des_set_sequence_number(), and
des_rand_data() functions are used in newer versions of
Kerberos but are not implemented here.
The des_random_key() function generated cryptographically
weak random data in SSLeay and in OpenSSL prior version
0.9.5, as well as in the original MIT library.
Author is Eric Young ([email protected]). Modified for the
OpenSSL project (http://www.openssl.org).
Functions: crypt(3), des_crypt(3), evp(3), rand_ssl(3)
Files: des_modes(7)
des(3)
[ Back ] |