Lithe Hash ist ein robustes Modul, das für das sichere Hashing von Passwörtern mithilfe des Bcrypt-Algorithmus entwickelt wurde. Dieses Modul vereinfacht den Prozess der Erstellung, Überprüfung und Verwaltung von Passwort-Hashes und stellt sicher, dass die besten Sicherheitspraktiken eingehalten werden.
Um das Lithemod/Hash-Paket zu installieren, können Sie Composer verwenden. Führen Sie den folgenden Befehl in Ihrem Terminal aus:
composer require lithemod/hash
Dadurch wird das Paket zu den Abhängigkeiten Ihres Projekts hinzugefügt, sodass Sie die Hash-Klasse in Ihrer Anwendung verwenden können.
Bevor Sie die Hash-Klasse verwenden, müssen Sie sie in Ihre PHP-Datei importieren:
use Lithe\Support\Security\Hash;
Um einen Hash aus einem Passwort zu erstellen, verwenden Sie die Methode make. Die Methode akzeptiert ein Passwort und eine optionale Reihe von Optionen:
$hash = Hash::make('sua_senha', ['cost' => 10]);
Parameter:
Rückgabe: Eine Hash-Zeichenfolge, die in einer Datenbank gespeichert werden kann.
Beispiel:
$password = 'minha_senha_segura'; $hash = Hash::make($password, ['cost' => 12]); echo "Senha Hashed: " . $hash;
Um zu überprüfen, ob ein Passwort mit dem Hash übereinstimmt, verwenden Sie die Methode check:
$isValid = Hash::check('sua_senha', $hash); if ($isValid) { echo 'Senha é válida!'; } else { echo 'Senha inválida.'; }
Parameter:
Rückgabe: true, wenn das Passwort mit dem Hash übereinstimmt; andernfalls falsch.
Beispiel:
if (Hash::check('minha_senha_segura', $hash)) { echo 'Senha está correta!'; } else { echo 'Senha está incorreta!'; }
Mit der Methode „needsRehash:
“ können Sie feststellen, ob ein Hash erneut aufbereitet werden muss (z. B. wenn Sie den Kostenfaktor ändern).
$needsRehash = Hash::needsRehash($hash, ['cost' => 14]); if ($needsRehash) { // Rehash com um novo custo $hash = Hash::make('sua_senha', ['cost' => 14]); }
Parameter:
Rückgabe: true, wenn der Hash erneut aufbereitet werden muss; andernfalls falsch.
Beispiel:
composer require lithemod/hash
Bcrypt ist eine weit verbreitete Passwort-Hashing-Funktion, die langsam und rechenintensiv ist und dadurch resistent gegen Brute-Force-Angriffe ist. Durch die Nutzung eines konfigurierbaren Kostenfaktors können Sie mit Bcrypt die Hashing-Schwierigkeit erhöhen, wenn die Hardware schneller wird.
Die make-Methode löst eine InvalidArgumentException aus, wenn die Kosten außerhalb des gültigen Bereichs (4 bis 31) liegen. Sie müssen dies in Ihrem Code behandeln, um Robustheit sicherzustellen:
use Lithe\Support\Security\Hash;
Das obige ist der detaillierte Inhalt vonLithe Hash: Ein robustes Modul für sicheres Passwort-Hashing. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!