rfc:timing_attack

This is an old revision of the document!


Request for Comments: Timing attack safe string comparison function

Introduction

Timing attacks are not a widely recognized problem, since they require significant skill and resources of the attacker. To prevent these attacks constant-time string comparisons can be used. These implementations are rather hard to get right, without leaking timing information.

While high profile applications and frameworks already ship with time-constant string comparison functions, this RFC aims to make it simpler for PHP developers to protect their applications. Additionally there's less chance of unexpected timing differences in lower level languages.

The password_verify function implemented in PHP 5.5 already does a time-constant string comparison, however in many projects bcrypt can not be used for some reason (legacy project, interfacing with other systems, etc.), but they'd still benefit from this functionality.

Proposal

Implement a new function called hash_compare as part of ext/hash.

Signature bool hash_compare(string knownString, string userString)

The time this function takes is based only on the length of the user supplied string.

Users have to be mindful, as it is important that the user supplied string (or a hash of that string) is used as the the second parameter not the first.

Backward Incompatible Changes

None.

Proposed PHP Version(s)

Next PHP 5.x

Impact to Existing Extensions

None.

Patches and Tests

Vote

Timing attack safe string comparison function
Real name Yes No
ajf  
andrey  
brianlmoon  
bwoebi  
chregu  
cpriest  
datibbaw  
derick  
indeyets  
klaussilveira  
krakjoe  
lstrojny  
malukenho  
mariuz  
nikic  
pajoye  
pollita  
seld  
shm  
stas  
treffynnon  
yohgaki  
zhangzhenyu  
Final result: 22 1
This poll has been closed.

References

Changelog

  • 0.1 Initial publication
  • 0.2 Renamed to hash_compare, added link to Zend Framework 2, removed information leak when knownString is empty (Thank you Tjerk)

* 1.0 Moved function to ext/hash. Started voting.

rfc/timing_attack.1391381196.txt.gz · Last modified: (external edit)