Struct openssl::crypto::hash::Hasher [] [src]

pub struct Hasher {
    // some fields omitted
}

Provides message digest (hash) computation.

Examples

Calculate a hash in one go.

use openssl::crypto::hash::{hash, Type};
let data = b"\x42\xF4\x97\xE0";
let spec = b"\x7c\x43\x0f\x17\x8a\xef\xdf\x14\x87\xfe\xe7\x14\x4e\x96\x41\xe2";
let res = hash(Type::MD5, data);
assert_eq!(res, spec);

Use the Write trait to supply the input in chunks.

use std::io::prelude::*;
use openssl::crypto::hash::{Hasher, Type};
let data = [b"\x42\xF4", b"\x97\xE0"];
let spec = b"\x7c\x43\x0f\x17\x8a\xef\xdf\x14\x87\xfe\xe7\x14\x4e\x96\x41\xe2";
let mut h = Hasher::new(Type::MD5);
h.write_all(data[0]);
h.write_all(data[1]);
let res = h.finish();
assert_eq!(res, spec);

Warning

Don't actually use MD5 and SHA-1 hashes, they're not secure anymore.

Don't ever hash passwords, use crypto::pkcs5 or bcrypt/scrypt instead.

Methods

impl Hasher

fn new(ty: Type) -> Hasher

Creates a new Hasher with the specified hash type.

fn finish(&mut self) -> Vec<u8>

Returns the hash of the data written since creation or the last finish and resets the hasher.

Trait Implementations

impl Write for Hasher

fn write(&mut self, buf: &[u8]) -> Result<usize>

fn flush(&mut self) -> Result<()>

fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>

fn write_fmt(&mut self, fmt: Arguments) -> Result<(), Error>

fn by_ref(&mut self) -> &mut Self

fn broadcast<W>(self, other: W) -> Broadcast<Self, W> where W: Write

impl Clone for Hasher

fn clone(&self) -> Hasher

fn clone_from(&mut self, source: &Self)

impl Drop for Hasher

fn drop(&mut self)