Usando di OpenSSL EVP interface (ciò che segue è per OpenSSL 1.1):
#include <iomanip>
#include <iostream>
#include <sstream>
#include <string>
#include <openssl/evp.h>
bool computeHash(const std::string& unhashed, std::string& hashed)
{
bool success = false;
EVP_MD_CTX* context = EVP_MD_CTX_new();
if(context != NULL)
{
if(EVP_DigestInit_ex(context, EVP_sha256(), NULL))
{
if(EVP_DigestUpdate(context, unhashed.c_str(), unhashed.length()))
{
unsigned char hash[EVP_MAX_MD_SIZE];
unsigned int lengthOfHash = 0;
if(EVP_DigestFinal_ex(context, hash, &lengthOfHash))
{
std::stringstream ss;
for(unsigned int i = 0; i < lengthOfHash; ++i)
{
ss << std::hex << std::setw(2) << std::setfill('0') << (int)hash[i];
}
hashed = ss.str();
success = true;
}
}
}
EVP_MD_CTX_free(context);
}
return success;
}
int main(int, char**)
{
std::string pw1 = "password1", pw1hashed;
std::string pw2 = "password2", pw2hashed;
std::string pw3 = "password3", pw3hashed;
std::string pw4 = "password4", pw4hashed;
hashPassword(pw1, pw1hashed);
hashPassword(pw2, pw2hashed);
hashPassword(pw3, pw3hashed);
hashPassword(pw4, pw4hashed);
std::cout << pw1hashed << std::endl;
std::cout << pw2hashed << std::endl;
std::cout << pw3hashed << std::endl;
std::cout << pw4hashed << std::endl;
return 0;
}
Il vantaggio di questa interfaccia di livello superiore è che è sufficiente sostituire la chiamata EVP_sha256()
con un'altra funzione di digest, ad es. EVP_sha512()
, per utilizzare un diverso digest. Quindi aggiunge una certa flessibilità.
Anche come bonus, sarebbe bello se emetterebbe l'hash in binario :) –
Ho pubblicato una nuova risposta lì che spiega quello che vuoi. Potresti chiudere questa domanda come duplicata se la risposta ti aiuta. – AndiDog
@AndiDog - Tutto sembra funzionare correttamente, tranne che il compilatore non riesce a trovare le funzioni. Non è nemmeno riuscito a trovare un riferimento a SHA1. Inoltre, non è possibile trovare alcuna funzione SHA256 come "SHA256_Final". Non sono sicuro di cosa sto facendo male, ho incluso #include "openssl/sha.h" e ho incluso l'inclusione e la libreria durante la compilazione -I/opt/ssl/include/-L/opt/ssl/lib/-lcrypto –