summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnthony Ferrara <ircmaxell@gmail.com>2013-05-28 15:30:45 -0400
committerAnthony Ferrara <ircmaxell@gmail.com>2013-05-28 15:30:45 -0400
commit540a5a52e89fce6da19d6f79dd1eda587a25b396 (patch)
tree69d3bb628f8d3516c5acb0c23c2fd2f67365be56
parent2f01e06786c6f4b2479fdb728bd26062d07208e0 (diff)
downloadphp-git-540a5a52e89fce6da19d6f79dd1eda587a25b396.tar.gz
Fix #64745 hash_pbkdf2 truncation issue
When using hash_pbkdf2 with hex output and 0 length (auto), it incorrectly truncates the result to 1/2 the expected result.
-rw-r--r--NEWS4
-rw-r--r--ext/hash/hash.c3
-rw-r--r--ext/hash/tests/bug64745.phpt17
3 files changed, 24 insertions, 0 deletions
diff --git a/NEWS b/NEWS
index b9a22261c9..d2d8aae30a 100644
--- a/NEWS
+++ b/NEWS
@@ -5,6 +5,10 @@ PHP NEWS
-FPM:
. Fixed Bug #64915 (error_log ignored when daemonize=0). (Remi)
+- Hash:
+ . Fixed Bug #64745 (hash_pbkdf2() truncates data when using default length
+ and hex output). (Anthony Ferrara)
+
23 May 2013, PHP 5.5.0 Release Candidate 2
- Core:
diff --git a/ext/hash/hash.c b/ext/hash/hash.c
index 9492387dbb..9cede14125 100644
--- a/ext/hash/hash.c
+++ b/ext/hash/hash.c
@@ -659,6 +659,9 @@ PHP_FUNCTION(hash_pbkdf2)
/* Setup Main Loop to build a long enough result */
if (length == 0) {
length = ops->digest_size;
+ if (!raw_output) {
+ length = length * 2;
+ }
}
digest_length = length;
if (!raw_output) {
diff --git a/ext/hash/tests/bug64745.phpt b/ext/hash/tests/bug64745.phpt
new file mode 100644
index 0000000000..427f89b728
--- /dev/null
+++ b/ext/hash/tests/bug64745.phpt
@@ -0,0 +1,17 @@
+--TEST--
+Bug #64745 hash_pbkdf2() truncates data when using default length and hex output
+--SKIPIF--
+<?php extension_loaded('hash') or die('skip'); ?>
+--FILE--
+<?php
+$hash = hash_pbkdf2('sha1', 'password', 'salt', 1, 0);
+$rawHash = hash_pbkdf2('sha1', 'password', 'salt', 1, 0, true);
+
+var_dump($hash);
+var_dump(bin2hex($rawHash));
+
+?>
+--EXPECT--
+string(40) "0c60c80f961f0e71f3a9b524af6012062fe037a6"
+string(40) "0c60c80f961f0e71f3a9b524af6012062fe037a6"
+