#bcrypt #password #web #hash

bcrypt

Easily hash and verify passwords using bcrypt

8 releases

0.2.0 Mar 16, 2018
0.1.6 Mar 16, 2018
0.1.5 Dec 5, 2017
0.1.4 Sep 25, 2017
0.1.0 Dec 24, 2015

#52 in Cryptography

Download history 163/week @ 2018-05-27 201/week @ 2018-06-03 136/week @ 2018-06-10 183/week @ 2018-06-17 170/week @ 2018-06-24 222/week @ 2018-07-01 250/week @ 2018-07-08 257/week @ 2018-07-15 277/week @ 2018-07-22 268/week @ 2018-07-29 343/week @ 2018-08-05 270/week @ 2018-08-12 179/week @ 2018-08-19

802 downloads per month
Used in 11 crates (7 directly)

MIT license

19KB
431 lines

bcrypt

Build Status Documentation

Installation

Add the following to Cargo.toml:

bcrypt = "0.2"

Usage

The crate makes 3 things public: DEFAULT_COST, hash, verify.

extern crate bcrypt;

use bcrypt::{DEFAULT_COST, hash, verify};

let hashed = hash("hunter2", DEFAULT_COST)?;
let valid = verify("hunter2", &hashed)?;

The cost needs to be an integer between 4 and 31 (see benchmarks to have an idea of the speed for each), the DEFAULT_COST is 12.

Benchmarks

Speed depends on the cost used: the highest the slowest. Here are some benchmarks on my 4 years old laptop to give you some ideas on the cost/speed ratio. Note that I don't go above 14 as it takes too long.

test bench_cost_4       ... bench:   1,197,414 ns/iter (+/- 112,856)
test bench_cost_10      ... bench:  73,629,975 ns/iter (+/- 4,439,106)
test bench_cost_default ... bench: 319,749,671 ns/iter (+/- 29,216,326)
test bench_cost_14      ... bench: 1,185,802,788 ns/iter (+/- 37,571,986)

Acknowledgments

This gist for the hash splitting and the null termination.

Changelog

  • 0.2.0: replace rust-crypto with blowfish, use some more modern Rust things like ? and handle more errors
  • 0.1.6: update rand and base64 deps
  • 0.1.5: update lazy-static to 1.0
  • 0.1.4: Replace rustc-serialize dependency with bcrypt
  • 0.1.3: Fix panic when password > 72 chars
  • 0.1.1: make BcryptResult, BcryptError public and update dependencies
  • 0.1.0: initial release

Dependencies

~1.5MB
~18K SLoC