⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hash_filehandle.c

📁 在BOOTLOADR中增加当今最好AES加密技术,可用于客户远程更新应用程式
💻 C
字号:
/* LibTomCrypt, modular cryptographic library -- Tom St Denis * * LibTomCrypt is a library that provides various cryptographic * algorithms in a highly modular and flexible manner. * * The library is free for all purposes without any express * guarantee it works. * * Tom St Denis, tomstdenis@gmail.com, http://libtomcrypt.com */#include "tomcrypt.h"/**   @file hash_filehandle.c   Hash open files, Tom St Denis*//**   Hash data from an open file handle.    @param hash   The index of the hash you want to use  @param in     The FILE* handle of the file you want to hash  @param out    [out] The destination of the digest  @param outlen [in/out] The max size and resulting size of the digest  @result CRYPT_OK if successful   */int hash_filehandle(int hash, FILE *in, unsigned char *out, unsigned long *outlen){#ifdef LTC_NO_FILE    return CRYPT_NOP;#else    hash_state md;    unsigned char buf[512];    size_t x;    int err;    LTC_ARGCHK(out    != NULL);    LTC_ARGCHK(outlen != NULL);    LTC_ARGCHK(in     != NULL);    if ((err = hash_is_valid(hash)) != CRYPT_OK) {        return err;    }    if (*outlen < hash_descriptor[hash].hashsize) {       return CRYPT_BUFFER_OVERFLOW;    }    if ((err = hash_descriptor[hash].init(&md)) != CRYPT_OK) {       return err;    }    *outlen = hash_descriptor[hash].hashsize;    do {        x = fread(buf, 1, sizeof(buf), in);        if ((err = hash_descriptor[hash].process(&md, buf, x)) != CRYPT_OK) {           return err;        }    } while (x == sizeof(buf));    err = hash_descriptor[hash].done(&md, out);#ifdef LTC_CLEAN_STACK    zeromem(buf, sizeof(buf));#endif    return err;#endif}/* $Source: /cvs/libtom/libtomcrypt/src/hashes/helper/hash_filehandle.c,v $ *//* $Revision: 1.4 $ *//* $Date: 2006/03/31 14:15:35 $ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -