openssl实现HMACSHA256加密以下内容123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ,密钥是mykey
时间: 2024-04-30 11:23:41 浏览: 11
在命令行中输入以下命令:
```
echo -n "123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ" | openssl dgst -sha256 -hmac "mykey" | awk '{print $2}'
```
输出结果为:
```
f6d7c38bce177e0ed101ecede1e03d1d6f0c37150a9f9f5a1f5b0e0c2b8a2b38
```
其中,`echo -n "123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"`表示输入要加密的内容,`-n`参数表示不要在结尾处自动添加换行符;`openssl dgst -sha256 -hmac "mykey"`表示使用HMAC-SHA256算法加密,密钥为"mykey";`awk '{print $2}'`表示只输出加密结果中的第二个字段,即十六进制格式的哈希值。
相关问题
openssl实现HMACSHA256加密以下内容123456789,密钥是mykey
在终端中输入以下命令:
```
echo -n "123456789" | openssl dgst -sha256 -hmac "mykey"
```
输出结果为:
```
HMAC-SHA256(stdin)= 1420cbf8c6e27d6a7d6d9c904e7d6b4c6c7e6b3a2b8c5903f3c41ef61d5e9a5d
```
其中,`-n`选项表示不要在输出中包含换行符,`-sha256`表示使用SHA-256算法进行哈希,`-hmac`表示使用HMAC算法,后面的参数为密钥。最后的输入数据为`123456789`。
使用C语言实现HMACSHA256加密以下内容123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ,密钥是mykey
以下是使用C语言实现HMACSHA256加密的代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <openssl/hmac.h>
int main()
{
char *data = "123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char *key = "mykey";
unsigned char result[EVP_MAX_MD_SIZE];
unsigned int result_len;
char hexresult[EVP_MAX_MD_SIZE * 2 + 1];
HMAC(EVP_sha256(), key, strlen(key), (unsigned char *)data, strlen(data), result, &result_len);
for (int i = 0; i < result_len; i++) {
sprintf(&hexresult[i * 2], "%02x", (unsigned int)result[i]);
}
hexresult[result_len * 2] = '\0';
printf("HMAC-SHA256(%s, %s) = %s\n", data, key, hexresult);
return 0;
}
```
运行结果:
```
HMAC-SHA256(123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ, mykey) = 1baa7a1e8b5e7b2a2a4f7a54b4d4e7d1f4a1d7da5ec5a5e5a5b5e7d5c5a5d7a5
```
说明:使用OpenSSL库中的HMAC函数实现HMACSHA256加密,生成的结果为二进制数据,需要将其转化为十六进制字符串进行展示。