首页 >后端开发 >C++ >如何使用 OpenSSL 和 C 生成 SHA256 哈希值:缺失函数的解决方案?

如何使用 OpenSSL 和 C 生成 SHA256 哈希值:缺失函数的解决方案?

Susan Sarandon
Susan Sarandon原创
2024-10-26 18:39:30499浏览

How to Generate SHA256 Hashes with OpenSSL and C  :  A Solution for Missing Functions?

使用 OpenSSL 和 C 生成 SHA256 哈希

当负责使用 SHA256 与 OpenSSL 和 C 创建哈希时,了解库的功能变得至关重要。其中一个实例遇到了缺少 OpenSSL 函数的问题,尽管包含了必要的头文件和构建路径。以下代码片段说明了解决方案:

<code class="cpp">void sha256_hash_string(unsigned char hash[SHA256_DIGEST_LENGTH], char outputBuffer[65]) {
  int i = 0;
  for (i = 0; i < SHA256_DIGEST_LENGTH; i++) {
    sprintf(outputBuffer + (i * 2), "%02x", hash[i]);
  }
  outputBuffer[64] = 0;
}

void sha256_string(char *string, char outputBuffer[65]) {
  unsigned char hash[SHA256_DIGEST_LENGTH];
  SHA256_CTX sha256;
  SHA256_Init(&sha256);
  SHA256_Update(&sha256, string, strlen(string));
  SHA256_Final(hash, &sha256);
  int i = 0;
  for (i = 0; i < SHA256_DIGEST_LENGTH; i++) {
    sprintf(outputBuffer + (i * 2), "%02x", hash[i]);
  }
  outputBuffer[64] = 0;
}

int sha256_file(char *path, char outputBuffer[65]) {
  FILE *file = fopen(path, "rb");
  if (!file) return -534;
  unsigned char hash[SHA256_DIGEST_LENGTH];
  SHA256_CTX sha256;
  SHA256_Init(&sha256);
  const int bufSize = 32768;
  unsigned char *buffer = malloc(bufSize);
  int bytesRead = 0;
  if (!buffer) return ENOMEM;
  while ((bytesRead = fread(buffer, 1, bufSize, file))) {
    SHA256_Update(&sha256, buffer, bytesRead);
  }
  SHA256_Final(hash, &sha256);
  sha256_hash_string(hash, outputBuffer);
  fclose(file);
  free(buffer);
  return 0;
}</code>

要使用此代码,请按照以下步骤操作:

<code class="cpp">static unsigned char buffer[65];
sha256("string", buffer);
printf("%s\n", buffer);</code>

此方法使用 OpenSSL 和 C 有效生成 SHA256 哈希值,解析包含路径之前遇到的问题。

以上是如何使用 OpenSSL 和 C 生成 SHA256 哈希值:缺失函数的解决方案?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn