首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C++ PBKDF2问题

C++ PBKDF2问题
EN

Stack Overflow用户
提问于 2017-07-13 00:13:41
回答 1查看 427关注 0票数 0

我有以下功能:

代码语言:javascript
复制
void PBKDF2_HMAC_SHA_512_string(const char* pass, const char* salt, int32_t iterations, uint32_t HashLength, char* out) {
    unsigned int i;
    HashLength = HashLength / 2;
    unsigned char* digest = new unsigned char[HashLength];
    PKCS5_PBKDF2_HMAC(pass, strlen(pass), (const unsigned char*)salt, strlen(salt), iterations, EVP_sha512(), HashLength, digest);
    for (i = 0; i < sizeof(digest); i++) {
        sprintf(out + (i * 2), "%02x", 255 & digest[i]);
    }
}

当我像下面这样调用函数时,我希望得到长度为2400的散列,但它返回16:

代码语言:javascript
复制
char PBKDF2Hash[1025]; //\0 terminating space?
memset(PBKDF2Hash, 0, sizeof(PBKDF2Hash));
PBKDF2_HMAC_SHA_512_string("Password", "0123456789123456", 3500, 1024, PBKDF2Hash);
//PBKDF2Hash is now always 16 long -> strlen(PBKDF2Hash),
//while I expect it to be 2400 long?
//How is this possible and why is this happening?
//I can't figure it out
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-07-13 01:54:36

因为digest是一个pointer,所以sizeof(digest)不会给出数组的长度。根据不同的平台,sizeof(digest)可能会给你4或8,这不是你想要的。也许你应该使用for (i = 0; i < HashLength; i++)

代码的另一个不相关的问题是,在PBKDF2_HMAC_SHA_512_string中没有删除digest,这会导致memory leak

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45062886

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档