| Recommend this page to a friend! |
| Info | Documentation | Reputation | Support forum | Blog | Links |
| Ratings | Unique User Downloads | Download Rankings | ||||
| Not yet rated by the users | Total: 93 | All time: 9,906 This week: 571 | ||||
| Version | License | PHP version | Categories | |||
| password_lock 1.0.0 | MIT/X Consortium ... | 5 | PHP 5, Cryptography, Security |
| Description | Author | |
This class can hash and encrypt passwords with Bcrypt and SHA2. |
MIT Licensed - feel free to use to enhance the security of any of your PHP projects
Wraps Bcrypt-SHA384 in Authenticated Encryption. Published by Paragon Initiative Enteprises. Check out our other open source projects too.
Depends on defuse/php-encryption for authenticated symmetric-key encryption.
Peppering strategies are usually accomplished through a keyed hash function (e.g. HMAC-SHA256) and applies to the password before it's passed to the salted hash API (i.e. bcrypt). If your pepper/HMAC key is ever compromised, you have to reset every user's password and it becomes a headache.
A hash then encrypt strategy offers agility; if your secret key is compromised (but, miraculously, the hashes are not), you can decrypt all of your users' hashes then re-encrypt them with a new key and they'll never suffer the inconvenience of an unscheduled password reset.
Here's a proof-of-concept for the first two points.
But realistically, this library is only about as a secure as bcrypt.
use \ParagonIE\PasswordLock\PasswordLock;
use \Defuse\Crypto\Key;
$key = Key::createNewRandomKey();
if (isset($_POST['password'])) {
if (!is_string($_POST['password'])) {
die("Password must be a string");
}
$storeMe = PasswordLock::hashAndEncrypt($_POST['password'], $key);
}
if (isset($_POST['password'])) {
if (!is_string($_POST['password'])) {
die("Password must be a string");
}
if (PasswordLock::decryptAndVerify($_POST['password'], $storeMe, $key)) {
// Success!
}
}
$newKey = \Defuse\Crypto\Key::createNewRandomKey();
$newHash = PasswordLock::rotateKey($storeMe, $key, $newKey);
$newHash = PasswordLock::upgradeFromVersion1(
$_POST['password'],
$oldHash,
$oldKey,
$newKey
);
If your company uses this library in their products or services, you may be interested in purchasing a support contract from Paragon Initiative Enterprises.
| File | Role | Description | ||
|---|---|---|---|---|
| Data | Auxiliary data | |||
| Aux. | Auxiliary script | |||
| Data | Auxiliary data | |||
| Data | Auxiliary data | |||
| Lic. | License text | |||
| Data | Auxiliary data | |||
| Data | Auxiliary data | |||
| Doc. | Documentation | |||
| Data | Auxiliary data | |||
| The PHP Classes site has supported package installation using the Composer tool since 2013, as you may verify by reading this instructions page. |
| Version Control | Unique User Downloads | Download Rankings | |||||||||||||||
| 100% |
|
|
| Applications that use this package |
If you know an application of this package, send a message to the author to add a link here.