gpt4 book ai didi

c++ - 如何使用 Crypto++ 库创建 HMAC 256?

转载 作者:行者123 更新时间:2023-11-27 22:48:59 25 4
gpt4 key购买 nike

我有一个字符串,我需要使用 C++ 和 Crypto++ 在 HMAC 256 中对其进行编码。来自图书馆的代码wiki :

AutoSeededRandomPool prng;
SecByteBlock key(16);
prng.GenerateBlock(key, key.size());

string plain = "HMAC Test";
string mac, encoded;

/*********************************\
\*********************************/

// Pretty print key
encoded.clear();
StringSource ss1(key, key.size(), true,
new HexEncoder(
new StringSink(encoded)
) // HexEncoder
); // StringSource

cout << "key: " << encoded << endl;
cout << "plain text: " << plain << endl;

/*********************************\
\*********************************/

try
{
HMAC< SHA256 > hmac(key, key.size());

StringSource ss2(plain, true,
new HashFilter(hmac,
new StringSink(mac)
) // HashFilter
); // StringSource
}
catch(const CryptoPP::Exception& e)
{
cerr << e.what() << endl;
exit(1);
}

/*********************************\
\*********************************/

// Pretty print
encoded.clear();
StringSource ss3(mac, true,
new HexEncoder(
new StringSink(encoded)
) // HexEncoder
); // StringSource

cout << "hmac: " << encoded << endl;

提供的示例有效,但似乎做了很多事情。我要做的就是:

  1. 取一个字符串:“GreatWallOfChina”
  2. key :m2hspk1ZxsjlsDU6JhMvD3TQQhm+zOwab3slKEILoSSnfk3b2+NUyeJiCrRAJ/D3V5y+QDZaIqRx9q9siMopaA==
  3. 将 key 转换为 base64:bTJoc3BrMVp4c2psc0RVNkpoTXZEM1RRUWhtK3pPd2FiM3NsS0VJTG9TU25mazNiMitOVXllSmlDclJBSi9EM1Y1eStRRFphSXFSeDlxOXNpTW9wYUE9PQ==
  4. 使用该 base64 key 创建 hmac256。

所以,我的问题是,上面示例代码中的所有步骤都是必要的吗? (字节 block 声明、十六进制编码等)

如果这是一个非常菜鸟的问题,我们深表歉意。

最佳答案

不,您的上述步骤当然不是必需的,例如对已经 base 64 编码的值进行 base 64 编码。

Crypto++ 主要基于带有接收器和源的流式传输。这就是库的设置方式,但对于小型计算来说,它会有些冗长。

请注意,大部分示例代码只是生成 key 并打印出明文、 key 和身份验证标记(MAC 值)以及一些异常处理。所需的代码基本上就在 try/catch block 中。

关于c++ - 如何使用 Crypto++ 库创建 HMAC 256?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39721005/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com