Source for file hash_equals.php
Documentation is available at hash_equals.php
- <?php
- /**
- * @package jelix
- * @subpackage auth
- * @author Laurent Jouanneau
- * @copyright 2015 Laurent Jouanneau
- * @licence http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public Licence, see LICENCE file
- */
-
- if(!function_exists('hash_equals')) {
- // already defined in PHP 5.6
- function hash_equals($known_str, $user_str) {
- if (!is_string($known_str)) {
- trigger_error("Expected known_str to be a string, $known_str given", E_USER_WARNING);
- return false;
- }
- if (!is_string($user_str)) {
- trigger_error("Expected user_str to be a string, $user_str given", E_USER_WARNING);
- return false;
- }
-
- $known_len = strlen($known_str);
- $user_len = strlen($user_str);
- if ($known_len != $user_len) {
- // if different lengths, do comparison as well, to have time constant
- // but return false as expected
- $user_str = $known_str;
- $result = 1;
- }
- else {
- $result = 0;
- }
-
- /* This is security sensitive code. Do not optimize this for speed. */
- for ($j = 0; $j < $known_len; $j++) {
- $result |= ord($known_str[$j] ^ $user_str[$j]);
- }
- return ($result == 0);
- }
- }
Documentation generated on Mon, 26 Oct 2015 21:51:18 +0100 by phpDocumentor 1.4.3