#openssl #password #key #salt #modern #evp-bytes-to-key

evpkdf

Rust implementation of OpenSSL EVP_bytesToKey function

3 unstable releases

0.2.0 Mar 19, 2023
0.1.1 Oct 7, 2021
0.1.0 Mar 1, 2020

#1567 in Cryptography

Download history 351/week @ 2024-09-18 269/week @ 2024-09-25 370/week @ 2024-10-02 327/week @ 2024-10-09 544/week @ 2024-10-16 533/week @ 2024-10-23 320/week @ 2024-10-30 348/week @ 2024-11-06 788/week @ 2024-11-13 345/week @ 2024-11-20 345/week @ 2024-11-27 371/week @ 2024-12-04 209/week @ 2024-12-11 206/week @ 2024-12-18 167/week @ 2024-12-25 252/week @ 2025-01-01

933 downloads per month
Used in 8 crates (via rust_filen)

MIT license

7KB

evpkdf

Rust implementation of OpenSSL EVP_bytesToKey function.

evpkdf derives key from the given password and salt.

Notice that this approach is too weak for modern standard now. Newer applications should choice a more modern algorithm like bcrypt, pbkdf2 or scrypt.

Basic Usage

use evpkdf::evpkdf;
use hex_literal::hex;
use md5::Md5;   // from md-5 crate
use sha1::Sha1; // from sha-1 crate

let mut output = [];

evpkdf::<Md5>(b"password", b"saltsalt", 1000, &mut output);

assert_eq!(output, []);

let mut output = [0; 128 / 8];

evpkdf::<Md5>(b"password", b"saltsalt", 1000, &mut output);

assert_eq!(output, hex!("8006de5d2a5d15f9bbdb8f40196d5af1"));

let mut output = [0; 128 / 8];

evpkdf::<Sha1>(b"password", b"saltsalt", 1000, &mut output);

assert_eq!(output, hex!("f8833429b112582447bc66f433497f75"));

Compatible with crypto-js

Below sinppet generates the same result as CryptoJS.kdf.OpenSSL.execute('password', 256 / 32, 128 / 32, 'saltsalt').

use evpkdf::evpkdf;
use hex_literal::hex;
use md5::Md5;   // from md-5 crate

const KEY_SIZE: usize = 256;
const IV_SIZE: usize = 128;

let mut output = [0; (KEY_SIZE + IV_SIZE) / 8];

evpkdf::<Md5>(b"password", b"saltsalt", 1, &mut output);

let (key, iv) = output.split_at(KEY_SIZE / 8);

assert_eq!(
    key,
    hex!("fdbdf3419fff98bdb0241390f62a9db35f4aba29d77566377997314ebfc709f2")
);

assert_eq!(
    iv,
    hex!("0b5ca7b1081f94b1ac12e3c8ba87d05a")
);

License

MIT

Dependencies

~345KB