Фасад Laravel Hash
обеспечивает безопасное хэширование Bcrypt и Argon2 для хранения паролей пользователей.
$password = Hash::make('plain-text-password');
Функция bcrypt
хеширует заданное значение с помощью Bcrypt. Вы можете использовать его как альтернативу Hash
фасаду:
$password = bcrypt('plain-text-password');
Как я могу получить "соль" из моего Auth, а также инструменты для получения зашифрованного пароля от мой простой пароль и «соль».
Проверка пароля против Ха sh
Метод check
позволяет вам проверить, соответствует ли данная строка простого текста данный га sh.
if (Hash::check('plain-text-password', $hashedPassword)) {
// The passwords match...
}
Обновление
Вы можете использовать Command или создать маршрут, чтобы изменить «простой текстовый» пароль для существующих клиентов.
Создать команду app / Console / Commands / ChangePassword. php
<?php
namespace App\Console\Commands;
use App\User;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\Hash;
class ChangePassword extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'change-password';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Plain-text password changer';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
$users = User::get();
foreach ($users as $user) {
if (Hash::needsRehash($user->password)) {
$user->password = Hash::make($user->password);
$user->save();
}
}
$this->info('Done..');
}
}
Использование:
php artisan change-password
После выполнения команды вы можете попробовать войти в систему по Auth::routes()
маршрутов.
или аутентификация пользователей вручную
if (Auth::attempt($credentials)) {
// Authentication passed...
}