编辑:我从这个问题({{3}})中提取了SHA3代码,而SHA3处于openssl 1.0.2q(而非1.0.2r)版本。
我正在尝试使用openssl库生成SHA3。
#include <stdio.h>
#include <openssl/evp.h>
unsigned int SHALEN=32;
void sha3(unsigned char *digest, const unsigned char *message, size_t message_len)
{
EVP_MD_CTX *mdctx;
mdctx = EVP_MD_CTX_create();
EVP_DigestInit_ex(mdctx, EVP_sha3_256(), NULL);
EVP_DigestUpdate(mdctx, message, message_len);
EVP_DigestFinal_ex(mdctx, digest, &SHALEN);
EVP_MD_CTX_destroy(mdctx);
}
int main()
{
unsigned char digest[32];
unsigned char message[32];
for(int i=0;i<32;i++)
message[i]=0;
sha3(digest,message,32);
}
以上代码在我的个人Mac(openssl 1.0.2q 2018Nov)上有效,但在服务器(Ubuntu 16.04,openssl version = 1.1.1a)上无效用
编译时 g++ test.cpp -lcrypto
它给
/tmp/ccXTFrzC.o: In function `sha3(unsigned char*, unsigned char const*, unsigned long)':
test.cpp:(.text+0x1e): undefined reference to `EVP_sha3_256'
collect2: error: ld returned 1 exit status
我查阅了openssl手册,但这不是很有帮助。我有什么想念的吗?预先感谢。
顺便说一句,建议不要降级openssl来解决问题。