1
は、ここでのOpenSSLウィキにEVP Message Digestsから取られた例です:EVP_DigestUpdateと「『CONSTのchar *』に 『* unsigned char型』から無効な変換」
void digest_message(unsigned char *message, unsigned char **digest, unsigned int *digest_len)
{
EVP_MD_CTX *mdctx;
if((mdctx = EVP_MD_CTX_create()) == NULL)
handleErrors();
if(1 != EVP_DigestInit_ex(mdctx, EVP_sha256(), NULL))
handleErrors();
if(1 != EVP_DigestUpdate(mdctx, message, strlen(message)))
handleErrors();
if((*digest = (unsigned char *)OPENSSL_malloc(EVP_MD_size(EVP_sha256()))) == NULL)
handleErrors();
if(1 != EVP_DigestFinal_ex(mdctx, *digest, digest_len))
handleErrors();
EVP_MD_CTX_destroy(mdctx);
}
問題は、私はそれをコンパイルしようとすると、私が手であります次のエラー:strlen
がconst char
を想定しているため
evp_test.cpp:18:60: error: invalid conversion from ‘unsigned char*’ to ‘const char*’ [-fpermissive]
if(1 != EVP_DigestUpdate(mdctx, message, strlen(message)))
In file included from /usr/include/c++/5/cstring:42:0
のでstrlen
メッセージに呼び出されると、エラーの原因は?これは文字列がconst chars
の配列なのでですか?
この問題を解決するには、どうしたらよいですか?
Lol ...私たちはOpenSSLのC++コンパイラサポートについて話していました。 [C++コンパイラでコンパイルするときのコンパイルエラー](https://mta.openssl.org/pipermail/openssl-dev/2016-March/006353.html)を参照してください。コンセンサスはC++コンパイラを「理由があるから」サポートしないことです。私が知る限り、技術的な理由はありません。 – jww