Próbuję napisać funkcję C za pomocą OpenSSL/libcrypto, aby obliczyć sumę SHA256 pliku. Opieram swój kod na przykładzie C++ Adama Lamera: here.Oblicz i wydrukuj skrót SHA256 pliku za pomocą OpenSSL
Oto mój kod:
int main (int argc, char** argv)
{
char calc_hash[65];
calc_sha256("file.txt", calc_hash);
}
int calc_sha256 (char* path, char output[65])
{
FILE* file = fopen(path, "rb");
if(!file) return -1;
char hash[SHA256_DIGEST_LENGTH];
SHA256_CTX sha256;
SHA256_Init(&sha256);
const int bufSize = 32768;
char* buffer = malloc(bufSize);
int bytesRead = 0;
if(!buffer) return -1;
while((bytesRead = fread(buffer, 1, bufSize, file)))
{
SHA256_Update(&sha256, buffer, bytesRead);
}
SHA256_Final(hash, &sha256);
sha256_hash_string(hash, output);
fclose(file);
free(buffer);
return 0;
}
void sha256_hash_string (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;
}
Problemem jest to .... przyjrzeć poniżej kwot obliczonych dla pliku Przykład:
Known good SHA256: 6da032d0f859191f3ec46a89860694c61e65460d54f2f6760b033fa416b73866
Calc. by my code: 6dff32ffff59191f3eff6affff06ffff1e65460d54ffff760b033fff16ff3866
ja również uzyskać * rozbijając wykryte stos * po zakończeniu wykonywania kodu.
Czy ktoś widzi, co robię źle?
Dzięki!
Mam zgłoszone prototypy. – dan6470
dlaczego const int bufSize jest naprawione o rozmiarze 32768? może to być mniej więcej –