Intereting Posts
Эмуляция названных параметров функции в PHP, хорошая или плохая идея? Является ли $ view в MVP-программе MVC правильным использованием глобальных переменных? Шифрование файла модуля smarty tpl в WHMCS SMTP: Не удалось подключить разъем: невозможно найти перенос сокета «ssl" PHP и MYSQL: как я могу игнорировать пустые переменные из Как различать запросы http и cli? cakephp 2.0 smtp email Nginx + php-fpm: ошибка тайм-аута 504 – тайм-аут восходящего потока (110: время ожидания подключения) Клиент SOAP через HTTPS с сертификатами SSL с обеих сторон PHP-тиснение с цветом Манипуляция строк PHP: извлечение hrefs В PHPStorm, как я могу сделать работу типа намека, когда у меня есть метод суперкласса, который возвращает другой тип из каждого подкласса Пытаться анализировать только изображения из RSS-ленты Неопределенный индекс HTTP_HOST, даже если он проверен Проблема получения изображения для сохранения

Настроить аутентификацию в Laravel

Я использую Laravel 5.1, и мне нужно использовать существующую таблицу пользователей, которая имеет свой собственный алгоритм пароля. После нескольких часов и часов исследований я нашел решение, и вот шаги. Надеюсь, это поможет Laravelers.

в файле config / auth.php, установите значение драйвера в пользовательский. как это.

... 'driver' => 'custom', ... 

создайте файл «CustomUserProvider.php» в каталоге приложений / Auth.

 <?php namespace App\Auth; use App\Model\User; use Carbon\Carbon; use Illuminate\Auth\GenericUser; use Illuminate\Contracts\Auth\Authenticatable; use Illuminate\Contracts\Auth\UserProvider; class CustomUserProvider implements UserProvider{ /** * Retrieve a user by their unique identifier. * * @param mixed $identifier * @return \Illuminate\Contracts\Auth\Authenticatable|null */ public function retrieveById($identifier){ $qry = User::where('id', '=', $identifier); if ($qry->count() > 0){ $user = $qry->select('id', 'firstName', 'lastName', 'city', 'state', 'zipcode', 'email', 'dob' , 'mobilePhone', 'password', 'question', 'answer', 'passwordSalt', 'promoCode', 'createdDate', 'isActivated', 'activationDate' , 'isDeleted', 'firstTimeLogin', 'role', 'remember_token')->first(); return $user; } return NULL; } /** * Retrieve a user by by their unique identifier and "remember me" token. * * @param mixed $identifier * @param string $token * @return \Illuminate\Contracts\Auth\Authenticatable|null */ public function retrieveByToken($identifier, $token){ $qry = User::where('id', '=', $identifier) ->where('remember_token', '=', $token); if ($qry->count() > 0){ $user = $qry->select('id', 'firstName', 'lastName', 'city', 'state', 'zipcode', 'email', 'dob' , 'mobilePhone', 'password', 'question', 'answer', 'passwordSalt', 'promoCode', 'createdDate', 'isActivated', 'activationDate' , 'isDeleted', 'firstTimeLogin', 'role', 'remember_token')->first(); return $user; } return NULL; } /** * Update the "remember me" token for the given user in storage. * * @param \Illuminate\Contracts\Auth\Authenticatable $user * @param string $token * @return void */ public function updateRememberToken(Authenticatable $user, $token){ $user->setRememberToken($token); $user->save(); } /** * Retrieve a user by the given credentials. * * @param array $credentials * @return \Illuminate\Contracts\Auth\Authenticatable|null */ public function retrieveByCredentials(array $credentials){ $qry = User::where('email', 'like', $credentials['email']); if ($qry->count() > 0){ $user = $qry->select('id', 'firstName', 'lastName', 'city', 'state', 'zipcode', 'email', 'dob' , 'mobilePhone', 'password', 'question', 'answer', 'passwordSalt', 'promoCode', 'createdDate', 'isActivated', 'activationDate' , 'isDeleted', 'firstTimeLogin', 'role', 'remember_token')->first(); return $user; } return NULL; } /** * Validate a user against the given credentials. * * @param \Illuminate\Contracts\Auth\Authenticatable $user * @param array $credentials * @return bool */ public function validateCredentials(Authenticatable $user, array $credentials){ $salt = base64_decode($user->passwordSalt); $password = $credentials['password']; $utf16Password = mb_convert_encoding($password, 'UTF-16LE', 'UTF-8'); $calculatedPassword = base64_encode(sha1($salt . $utf16Password, true)); if ($user->email == $credentials['email'] && $user->getAuthPassword() == $calculatedPassword){ return true; } return false; } } ?> 

затем создайте файл «CustomAuthProvider.php» в каталоге app / Providers.

 <?php namespace App\Providers; use App\Auth\CustomUserProvider; use Illuminate\Support\ServiceProvider; class CustomAuthProvider extends ServiceProvider{ /** * Bootstrap the application services. * * @return void */ public function boot(){ $this->app['auth']->extend('custom', function(){ return new CustomUserProvider(); }); } /** * Register the application services. * * @return void */ public function register(){ // } } ?> 

Вот и все.