Minimal HMAC-SHA256 implementation in C / C++ https://github.com/h5p9sl/hmac_sha256
Go to file
Tyler 76ac6669de
Update README.md
2020-01-15 23:21:00 -07:00
README.md Update README.md 2020-01-15 23:21:00 -07:00
WjCryptLib_Sha256.c Initial Commit 2019-05-19 21:43:18 -06:00
WjCryptLib_Sha256.h Initial Commit 2019-05-19 21:43:18 -06:00
hmac_sha256.c Initial Commit 2019-05-19 21:43:18 -06:00
hmac_sha256.h Add C++ compatibility 2019-07-04 20:27:00 -06:00

README.md

hmac_sha256

A SHA256 HMAC implementation in C/C++

Usage Example (C++)

#include "hmac_sha256.h"

#include <vector>
#include <string>
#include <iostream>
#include <sstream>

#define SHA256_HASHLEN 32

int main() {
    // This is what the hmac_sha256 value should output
    const std::string testvector = "b0344c61d8db38535ca8afceafbf12b881dc20c9833da726e9376c2e32cff7";
    const std::string str_data = "Hi There";

    std::vector<uint8_t> key, data, out;
    std::stringstream result;

    // Allocate memory using C++ std::vector
    key.resize(20, 0x0b);
    data.resize(str_data.length(), 0);
    out.resize(SHA256_HASHLEN, 0);

    // Fill `data` with `str_data`'s bytes
    data.assign(str_data.cbegin(), str_data.cend());

    // Call hmac-sha256 function
    hmac_sha256(
        key.data(),  key.size(),
        data.data(), data.size(),
        out.data(),  out.size()
    );

    // Convert `out` to string with std::hex
    for (size_t i = 0; i < out.size(); i++) {
        result << std::hex << (int)out[i];
    }
    std::cout << result.str() << std::endl;
    std::cout << testvector << std::endl;

    // Compare result
    if (testvector.compare(result.str()) == 0) {
        std::cout << "Test passed!" << std::endl;
    } else {
        std::cout << "Test failed." << std::endl;
    }

    return 0;
}