View source code
Display the source code in std/digest/sha.d from which this
page was generated on github.
Report a bug
If you spot a problem with this page, click here to create a
Bugzilla issue.
Improve this page
Quickly fork, edit online, and submit a pull request for this page.
Requires a signed-in GitHub account. This works well for small changes.
If you'd like to make larger changes you may want to consider using
local clone.
Alias std.digest.sha.SHA1Digest
OOP API SHA1 and SHA2 implementations.
See std
for differences between template and OOP API.
alias SHA1Digest
= std .digest .WrapperDigest!(std.digest.sha.SHA!(512,160).SHA);
This is an alias for
, see
there for more information.
std
!SHA1
Example
//Simple example, hashing a string using Digest.digest helper function
auto sha = new SHA1Digest();
ubyte[] hash = sha .digest("abc");
//Let's get a hash string
writeln(toHexString(hash)); // "A9993E364706816ABA3E25717850C26C9CD0D89D"
//The same, but using SHA-224
auto sha224 = new SHA224Digest();
ubyte[] hash224 = sha224 .digest("abc");
//Let's get a hash string
writeln(toHexString(hash224)); // "23097D223405D8228642A477BDA255B32AADBCE4BDA0B3F7E36C9DA7"
Example
//Let's use the OOP features:
void test(Digest dig)
{
dig .put(cast(ubyte) 0);
}
auto sha = new SHA1Digest();
test(sha);
//Let's use a custom buffer:
ubyte[20] buf;
ubyte[] result = sha .finish(buf[]);
writeln(toHexString(result)); // "5BA93C9DB0CFF93F52B521D7420E43F6EDA2784F"
Authors
The routines and algorithms are derived from the
Secure Hash Signature Standard (SHS) (FIPS PUB 180-2).
Kai Nacke, Johannes Pfau, Nick Sabalausky
License
Copyright © 1999-2024 by the D Language Foundation | Page generated by ddox.