Changeset 29382
- Timestamp:
- 08/06/2014 05:25:03 AM (10 years ago)
- Location:
- trunk/src/wp-includes
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/wp-includes/compat.php
r18404 r29382 95 95 } 96 96 } 97 98 if ( ! function_exists( 'hash_equals' ) ) : 99 /** 100 * Compare two strings in constant time. 101 * 102 * This function was added in PHP 5.6. 103 * It can leak the length of a string. 104 * 105 * @since 3.9.2 106 * 107 * @param string $a Expected string. 108 * @param string $b Actual string. 109 * @return bool Whether strings are equal. 110 */ 111 function hash_equals( $a, $b ) { 112 $a_length = strlen( $a ); 113 if ( $a_length !== strlen( $b ) ) { 114 return false; 115 } 116 $result = 0; 117 118 // Do not attempt to "optimize" this. 119 for ( $i = 0; $i < $a_length; $i++ ) { 120 $result |= ord( $a[ $i ] ) ^ ord( $b[ $i ] ); 121 } 122 123 return $result === 0; 124 } 125 endif; -
trunk/src/wp-includes/pluggable.php
r29221 r29382 672 672 $hash = hash_hmac( 'sha256', $username . '|' . $expiration . '|' . $token, $key ); 673 673 674 if ( hash_hmac( 'sha256', $hmac, $key ) !== hash_hmac( 'sha256', $hash, $key) ) {674 if ( ! hash_equals( $hash, $hmac ) ) { 675 675 /** 676 676 * Fires if a bad authentication cookie hash is encountered. … … 1712 1712 1713 1713 // Nonce generated 0-12 hours ago 1714 if ( $nonce === substr( wp_hash( $i . '|' . $action . '|' . $uid . '|' . $token, 'nonce'), -12, 10 ) ) { 1714 $expected = substr( wp_hash( $i . '|' . $action . '|' . $uid . '|' . $token, 'nonce'), -12, 10 ); 1715 if ( hash_equals( $expected, $nonce ) ) { 1715 1716 return 1; 1716 1717 } 1717 1718 1718 1719 // Nonce generated 12-24 hours ago 1719 if ( $nonce === substr( wp_hash( ( $i - 1 ) . '|' . $action . '|' . $uid . '|' . $token, 'nonce' ), -12, 10 ) ) { 1720 $expected = substr( wp_hash( ( $i - 1 ) . '|' . $action . '|' . $uid . '|' . $token, 'nonce' ), -12, 10 ); 1721 if ( hash_equals( $expected, $nonce ) ) { 1720 1722 return 2; 1721 1723 }
Note: See TracChangeset
for help on using the changeset viewer.