Linux C 下使用openssl 進行SHA1加密

weixin_34026276發表於2017-11-07
How to replace hash functions from openssl with gcrypt. I wondered how to do it, and hacked around. git source uses ssl, and I wanted that to change.
/*
 Code snippet to calculate SHA1sum using openssl libs.
 Copyright 2005 Junichi Uekawa, given to public domain.

$ gcc openssltest.c -lssl
$ ./a.out  < ./a.out
eae8189278303caaa78f2d89e6a6ebeb7d37b554
$ sha1sum ./a.out
eae8189278303caaa78f2d89e6a6ebeb7d37b554  ./a.out
*/

#include 
<stdio.h>
#include 
<openssl/sha.h>

main ()
{
  SHA_CTX s;
  
int i, size;
  
char c[512];
  unsigned 
char hash[20];
  
  SHA1_Init(
&s);
  
while ((size=read (0, c, 512)) > 0)
    SHA1_Update(
&s, c, size);
  SHA1_Final(hash, 
&s);
  
  
for (i=0; i < 20; i++)
    printf (
"%.2x", (int)hash[i]);
  printf (
"\n");
}


    本文轉自 OldHawk  部落格園部落格,原文連結:http://www.cnblogs.com/taobataoma/archive/2007/05/11/743257.html,如需轉載請自行聯絡原作者


相關文章