曲径通幽论坛

标题: sha1 -- 生成 sha1 散列值 [打印本页]

作者: beyes    时间: 2012-9-25 22:47
标题: sha1 -- 生成 sha1 散列值
SHA 是 Secure Hash Algorithm (安全散列算法) 的缩写,它用来产生 20 个字节 (160位) 的散列值,该算法常用于数字签名,以防止数据遭到篡改。

这里介绍 openssl 提供 API 计算数据的 SHA1 值。实际上,该 API 有两套,这里只给出最简单的函数,即  SHA1(),其原型如下:
[C++] 纯文本查看 复制代码
#include <openssl/sha.h>

         unsigned char *SHA1(const unsigned char *d, unsigned long n,
                          unsigned char *md);

函数中的第 1 个参数 d 表示要处理的数据;第 2 个参数 n 表示该数据的长度;第 3 个参数 md 表示计算出的 sha 值的存放地方,如果为 NULL,那么系统会安排一个静态缓冲区对其存储。

测试代码:
[C++] 纯文本查看 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <openssl/sha.h>

#define SHA1LEN SHA_DIGEST_LENGTH

static const char hex_chars[] = "0123456789abcdef";
  
void convert_hex(unsigned char *md, unsigned char *mdstr)
{
     int i;
     int j = 0;
     unsigned int c;
  
     for (i = 0; i < 20; i++) {
         c = (md >> 4) & 0x0f;
         mdstr[j++] = hex_chars[c];
         mdstr[j++] = hex_chars[md & 0x0f];
     }
     mdstr[40] = '\0';
}

int main(int argc, char **argv)
{
     if (argc != 2) {
        fprintf (stderr, "usage: %s your-string\n", argv[0]);
        exit (EXIT_FAILURE);
     }
     
     char md[SHA_DIGEST_LENGTH];
     char mdstr[40];

     bzero(md, SHA_DIGEST_LENGTH);
     bzero(mdstr, 40);
     
     SHA1(argv[1], strlen(argv[1]), md);

     convert_hex(md, mdstr);

     printf ("Result of SHA1 : %s\n", mdstr);

     return 0;
}

运行输出:
beyes:/home/beyes/c/openssl # ./sha1 groad.net
Result of SHA1 : f6f80b59f1b25c82b64d857594fee53cd0df3604





欢迎光临 曲径通幽论坛 (http://www.groad.net/bbs/) Powered by Discuz! X3.2