mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
util.hashes: Fix output length of PBKDF2-HMAC-SHA256
Somehow it got SHA1's 20 byte output instead of the proper 32 = 256/8
This commit is contained in:
parent
91e76bc97e
commit
d146b0d68a
2 changed files with 19 additions and 1 deletions
|
@ -35,3 +35,21 @@ describe("PBKDF2-HMAC-SHA1", function ()
|
|||
end);
|
||||
end);
|
||||
|
||||
describe("PBKDF2-HMAC-SHA256", function ()
|
||||
it("test vector 1", function ()
|
||||
local P = "password";
|
||||
local S = "salt";
|
||||
local c = 1
|
||||
local DK = "120fb6cffcf8b32c43e7225256c4f837a86548c92ccc35480805987cb70be17b";
|
||||
assert.equal(DK, hex.to(hashes.pbkdf2_hmac_sha256(P, S, c)));
|
||||
end);
|
||||
it("test vector 2", function ()
|
||||
local P = "password";
|
||||
local S = "salt";
|
||||
local c = 2
|
||||
local DK = "ae4d0c95af6b46d32d0adff928f06dd02a303f8ef3c251dfd6e2d85a95474c43";
|
||||
assert.equal(DK, hex.to(hashes.pbkdf2_hmac_sha256(P, S, c)));
|
||||
end);
|
||||
end);
|
||||
|
||||
|
||||
|
|
|
@ -129,7 +129,7 @@ static int Lpbkdf2_sha256(lua_State *L) {
|
|||
return luaL_error(L, "PKCS5_PBKDF2_HMAC() failed");
|
||||
}
|
||||
|
||||
lua_pushlstring(L, (char *)out, SHA_DIGEST_LENGTH);
|
||||
lua_pushlstring(L, (char *)out, SHA256_DIGEST_LENGTH);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue