OPENSSL 将二进制字节转换为 SHA256 C++

OPENSSL Convert binary bytes to SHA256 C++

我基本上是在尝试为我的助记词获取校验和。 我有二进制字节,想将它们转换为 sha256 以获得前 4 位并对其进行验证。

我花了大约 2 天时间才意识到散列从文本字符串到 sha256 与字节到 sha256 不同。 下面的函数有效,但它散列为字符串而不是字节。

string sha256(const string str)
{
    unsigned char hash[SHA256_DIGEST_LENGTH];
    SHA256_CTX sha256;
    SHA256_Init(&sha256);
    SHA256_Update(&sha256, str.c_str(), str.size());
    SHA256_Final(hash, &sha256);
    stringstream ss;
    for(int i = 0; i < SHA256_DIGEST_LENGTH; i++)
    {
        ss << hex << setw(2) << setfill('0') << (int)hash[i];
    }
    return ss.str();
}

我是 openssl 的新手,无法在线找到任何解决方案。 如果有人可以调整我的函数以正确散列二进制字节输入,我将非常感激。 谢谢。

为了阐明这里有一个例子: 101111100110010101011101110011111010100011111011010110001110101111011110111000101101001100011110100010100011101000011011010=11[1020]

this used as text 给我这个散列: 2d7ffa3c8f9c3fc043045f2564101eabf80bcdb983d1d560b6b93f52ea824942

并用作字节给我这个正确的散列: 5e5c92432e692f803539715bb624cd2e35b5b491c6bc67aee87ae82600dedf12

我用这个网站来哈希:https://cryptii.com/hash-function

所以您似乎需要将输入解释为比特流。将它们分组为字节,然后开始:

unsigned char hash[SHA256_DIGEST_LENGTH];
SHA256_CTX sha256;
SHA256_Init(&sha256);
uint8_t str[] = { 0b10111110, 0b01100101, 0b01011101, 0b11001111, 0b01010001, 0b11110110, 0b10110001, 0b11010111, 0b10111101, 0b11000101, 0b10100110, 0b00111101, 0b00010100, 0b01110100, 0b00110110, 0b11100000 };
SHA256_Update(&sha256, str, sizeof(str));
SHA256_Final(hash, &sha256);

哈希输出:

5e5c92432e692f803539715bb624cd2e35b5b491c6bc67aee87ae82600dedf12

Live demo