Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stbrumme/hash-library
Portable C++ hashing library
https://github.com/stbrumme/hash-library
crc32 endian-independent hmac keccak md5 portable sha1 sha256 sha3
Last synced: 13 days ago
JSON representation
Portable C++ hashing library
- Host: GitHub
- URL: https://github.com/stbrumme/hash-library
- Owner: stbrumme
- License: zlib
- Created: 2018-08-09T15:25:02.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-10-10T19:12:58.000Z (about 1 year ago)
- Last Synced: 2024-08-01T19:52:57.747Z (3 months ago)
- Topics: crc32, endian-independent, hmac, keccak, md5, portable, sha1, sha256, sha3
- Language: C++
- Homepage: https://create.stephan-brumme.com/hash-library/
- Size: 12.7 KB
- Stars: 473
- Watchers: 14
- Forks: 136
- Open Issues: 9
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
# Portable C++ Hashing Library
This is a mirror of my library hosted at https://create.stephan-brumme.com/hash-library/
In a nutshell:
- computes CRC32, MD5, SHA1 and SHA256 (most common member of the SHA2 functions), Keccak and its SHA3 sibling
- optional HMAC (keyed-hash message authentication code)
- no external dependencies, small code size
- can work chunk-wise (for example when reading streams block-by-block)
- portable: supports Windows and Linux, tested on Little Endian and Big Endian CPUs
- roughly as fast as Linux core hashing functions
- open source, zlib licenseYou can find code examples, benchmarks and much more on my website https://create.stephan-brumme.com/hash-library/
# How to use
This example computes SHA256 hashes but the API is more or less identical for all hash algorithms:
``` cpp
// SHA2 test program
#include "sha256.h"
#include // for std::cout only, not needed for hashing libraryint main(int, char**)
{
// create a new hashing object
SHA256 sha256;// hashing an std::string
std::cout << sha256("Hello World") << std::endl;
// => a591a6d40bf420404a011733cfb7b190d62c65bf0bcda32b57b277d9ad9f146e// hashing a buffer of bytes
const char* buffer = "How are you";
std::cout << sha256(buffer, 11) << std::endl;
// => 9c7d5b046878838da72e40ceb3179580958df544b240869b80d0275cc07209cc// or in a streaming fashion (re-use "How are you")
SHA256 sha256stream;
const char* url = "create.stephan-brumme.com"; // 25 bytes
int step = 5;
for (int i = 0; i < 25; i += step)
sha256stream.add(url + i, step); // add five bytes at a time
std::cout << sha256stream.getHash() << std::endl;
// => 82aa771f1183c52f973c798c9243a1c73833ea40961c73e55e12430ec77b69f6return 0;
}
```