Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Commit20bc2c2

Browse files
committed
Use bcrypt as default password hash algorithm for "native" and "auto"
1 parent163df1e commit20bc2c2

File tree

4 files changed

+24
-6
lines changed

4 files changed

+24
-6
lines changed

‎src/Symfony/Component/PasswordHasher/CHANGELOG.md‎

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2,3 +2,4 @@
22
---
33

44
* Add the component
5+
* Use`bcrypt` as default algorithm in`NativePasswordHasher`

‎src/Symfony/Component/PasswordHasher/Hasher/NativePasswordHasher.php‎

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,7 @@ final class NativePasswordHasher implements PasswordHasherInterface
2929
private$options;
3030

3131
/**
32-
* @param string|null $algo An algorithm supported by password_hash() or null to use thestronger available algorithm
32+
* @param string|null $algo An algorithm supported by password_hash() or null to use thebest available algorithm
3333
*/
3434
publicfunction__construct(int$opsLimit =null,int$memLimit =null,int$cost =null, ?string$algo =null)
3535
{
@@ -52,15 +52,18 @@ public function __construct(int $opsLimit = null, int $memLimit = null, int $cos
5252
$algos = [1 => \PASSWORD_BCRYPT,'2y' => \PASSWORD_BCRYPT];
5353

5454
if (\defined('PASSWORD_ARGON2I')) {
55-
$this->algo =$algos[2] =$algos['argon2i'] = (string) \PASSWORD_ARGON2I;
55+
$algos[2] =$algos['argon2i'] = (string) \PASSWORD_ARGON2I;
5656
}
5757

5858
if (\defined('PASSWORD_ARGON2ID')) {
59-
$this->algo =$algos[3] =$algos['argon2id'] = (string) \PASSWORD_ARGON2ID;
59+
$algos[3] =$algos['argon2id'] = (string) \PASSWORD_ARGON2ID;
6060
}
6161

6262
if (null !==$algo) {
6363
$this->algo =$algos[$algo] ??$algo;
64+
}else {
65+
// use bcrypt as default
66+
$this->algo =$algos[1];
6467
}
6568

6669
$this->options = [

‎src/Symfony/Component/PasswordHasher/Hasher/PasswordHasherFactory.php‎

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -11,9 +11,9 @@
1111

1212
namespaceSymfony\Component\PasswordHasher\Hasher;
1313

14-
useSymfony\Component\Security\Core\Encoder\EncoderAwareInterface;
1514
useSymfony\Component\PasswordHasher\Exception\LogicException;
1615
useSymfony\Component\PasswordHasher\PasswordHasherInterface;
16+
useSymfony\Component\Security\Core\Encoder\EncoderAwareInterface;
1717

1818
/**
1919
* A generic hasher factory implementation.
@@ -103,9 +103,15 @@ private function createHasher(array $config, bool $isExtra = false): PasswordHas
103103
privatefunctiongetHasherConfigFromAlgorithm(array$config):array
104104
{
105105
if ('auto' ===$config['algorithm']) {
106-
$hasherChain = [];
107106
// "plaintext" is not listed as any leaked hashes could then be used to authenticate directly
108-
foreach ([SodiumPasswordHasher::isSupported() ?'sodium' :'native','pbkdf2',$config['hash_algorithm']]as$algo) {
107+
if (SodiumPasswordHasher::isSupported()) {
108+
$algos = ['native','sodium','pbkdf2',$config['hash_algorithm']];
109+
}else {
110+
$algos = ['native','pbkdf2',$config['hash_algorithm']];
111+
}
112+
113+
$hasherChain = [];
114+
foreach ($algosas$algo) {
109115
$config['algorithm'] =$algo;
110116
$hasherChain[] =$this->createHasher($config,true);
111117
}

‎src/Symfony/Component/PasswordHasher/Tests/Hasher/NativePasswordHasherTest.php‎

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -73,6 +73,14 @@ public function testConfiguredAlgorithm()
7373
$this->assertStringStartsWith('$2',$result);
7474
}
7575

76+
publicfunctiontestDefaultAlgorithm()
77+
{
78+
$hasher =newNativePasswordHasher(null,null,null, \PASSWORD_BCRYPT);
79+
$result =$hasher->hash('password',null);
80+
$this->assertTrue($hasher->verify($result,'password',null));
81+
$this->assertStringStartsWith('$2',$result);
82+
}
83+
7684
publicfunctiontestConfiguredAlgorithmWithLegacyConstValue()
7785
{
7886
$hasher =newNativePasswordHasher(null,null,null,'1');

0 commit comments

Comments
 (0)

[8]ページ先頭

©2009-2025 Movatter.jp