std.digest.md
Computes MD5 hashes of arbitrary data. MD5 hashes are 16 byte quantities that are like a checksum or CRC, but are more robust.
| Category | Functions |
|---|---|
| Template API | MD5 |
| OOP API | MD5Digest |
| Helpers | md5Of |
This module conforms to the APIs defined in std.digest. To understand the differences between the template and the OOP API, see std.digest.
This module publicly imports std.digest and can be used as a stand-alone module.
- License:
- Boost License 1.0.
- CTFE
- Digests do not work in CTFE
- Authors:
- Piotr Szturmaj, Kai Nacke, Johannes Pfau
The routines and algorithms are derived from the RSA Data Security, Inc. MD5 Message-Digest Algorithm.
- References
- Wikipedia on MD5
- Source
- std/digest/md.d
- Examples:
-
//Template API import std.digest.md; //Feeding data ubyte[1024] data; MD5 md5; md5.start(); md5.put(data[]); md5.start(); //Start again md5.put(data[]); auto hash = md5.finish();
- Examples:
-
//OOP API import std.digest.md; auto md5 = new MD5Digest(); ubyte[] hash = md5.digest("abc"); writeln(toHexString(hash)); // "900150983CD24FB0D6963F7D28E17F72" //Feeding data ubyte[1024] data; md5.put(data[]); md5.reset(); //Start again md5.put(data[]); hash = md5.finish();
- struct MD5;
-
Template API MD5 implementation. See
std.digestfor differences between template and OOP API.- Examples:
-
//Simple example, hashing a string using md5Of helper function ubyte[16] hash = md5Of("abc"); //Let's get a hash string writeln(toHexString(hash)); // "900150983CD24FB0D6963F7D28E17F72"
- Examples:
-
//Using the basic API MD5 hash; hash.start(); ubyte[1024] data; //Initialize data here... hash.put(data); ubyte[16] result = hash.finish();
- Examples:
-
//Let's use the template features: void doSomething(T)(ref T hash) if (isDigest!T) { hash.put(cast(ubyte) 0); } MD5 md5; md5.start(); doSomething(md5); writeln(toHexString(md5.finish())); // "93B885ADFE0DA089CDF634904FD59F71"
- pure nothrow @nogc @trusted void put(scope const(ubyte)[] data...);
-
Use this to feed the digest with data. Also implements the
std.range.primitives.isOutputRangeinterface forubyteandconst(ubyte)[].- Example
MD5 dig; dig.put(cast(ubyte) 0); //single ubyte dig.put(cast(ubyte) 0, cast(ubyte) 0); //variadic ubyte[10] buf; dig.put(buf); //buffer
- pure nothrow @nogc @safe void start();
-
Used to (re)initialize the MD5 digest.
- Note
- For this MD5 Digest implementation calling start after default construction is not necessary. Calling start is only necessary to reset the Digest.
- Example
MD5 digest; //digest.start(); //Not necessary digest.put(0);
- pure nothrow @nogc @trusted ubyte[16] finish();
-
Returns the finished MD5 hash. This also calls
startto reset the internal state.- Examples:
-
//Simple example MD5 hash; hash.start(); hash.put(cast(ubyte) 0); ubyte[16] result = hash.finish();
- auto md5Of(T...)(T data);
-
This is a convenience alias for
std.digest.digestusing the MD5 implementation.- Examples:
-
ubyte[16] hash = md5Of("abc"); writeln(hash); // digest!MD5("abc")
- alias MD5Digest = std.digest.WrapperDigest!(MD5).WrapperDigest;
-
OOP API MD5 implementation. See
std.digestfor differences between template and OOP API.This is an alias for
std.digest.WrapperDigest!MD5, see there for more information.- Examples:
-
//Simple example, hashing a string using Digest.digest helper function auto md5 = new MD5Digest(); ubyte[] hash = md5.digest("abc"); //Let's get a hash string writeln(toHexString(hash)); // "900150983CD24FB0D6963F7D28E17F72"
- Examples:
-
//Let's use the OOP features: void test(Digest dig) { dig.put(cast(ubyte) 0); } auto md5 = new MD5Digest(); test(md5); //Let's use a custom buffer: ubyte[16] buf; ubyte[] result = md5.finish(buf[]); writeln(toHexString(result)); // "93B885ADFE0DA089CDF634904FD59F71"
© 1999–2021 The D Language Foundation
Licensed under the Boost License 1.0.
https://dlang.org/phobos/std_digest_md.html