問題描述
據我所知,Auth::attempt
用于對 users
表中的用戶進行身份驗證,但我想對 managers
表中的其他用戶進行身份驗證和 admins
表中的 admin.我知道已經存在 laravel-multiauth
插件.但是我們可以創建自己的 AuthServiceProvider
來對來自多個表的用戶進行身份驗證嗎?
As I know Auth::attempt
is used to authenticate users from users
table, but i want to authenticate another users from managers
table and admin from admins
table. I know there are laravel-multiauth
plugin already exist. But can we create our own AuthServiceProvider
for authenticating users from multiple tables..?
推薦答案
首先在 IlluminateFoundationAuth
中創建 Admin Authenticatable 就像
First create Admin Authenticatable in IlluminateFoundationAuth
like
<?php
namespace IlluminateFoundationAuth;
use IlluminateAuthAuthenticatable;
use IlluminateDatabaseEloquentModel;
use IlluminateAuthPasswordsCanResetPassword;
use IlluminateFoundationAuthAccessAuthorizable;
use IlluminateContractsAuthAuthenticatable as AuthenticatableContract;
use IlluminateContractsAuthAccessAuthorizable as AuthorizableContract;
use IlluminateContractsAuthCanResetPassword as CanResetPasswordContract;
class Admin extends Model implements
AuthenticatableContract,
AuthorizableContract,
CanResetPasswordContract
{
use Authenticatable, Authorizable, CanResetPassword;
}
然后通過擴展Authenticatable
管理模型來創建管理模型:-
Then create Admin Model by extending Authenticatable
Admin Model :-
<?php
namespace App;
use IlluminateFoundationAuthAdmin as Authenticatable;
class Admin extends Authenticatable
{
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
}
之后你需要像下面這樣修改config/auth.php
添加提供者數組
After that you need to modify config/auth.php
like below
Add in providers array
'admins' => [
'driver' => 'eloquent',
'model' => AppAdmin::class,
],
并加入guards數組.
'user' => [
'driver' => 'session',
'provider' => 'users',
],
'admin' => [
'driver' => 'session',
'provider' => 'admins',
],
現在從用戶表進行身份驗證
if (Auth::guard('user')->attempt(['email' => $email, 'password' => $password])) {
$details = Auth::guard('user')->user();
$user = $details['original'];
return $user;
} else {
return 'auth fail';
}
并從Admin表進行身份驗證
if (Auth::guard('admin')->attempt(['email' => $email, 'password' => $password])) {
$details = Auth::guard('admin')->user();
$user = $details['original'];
return $user;
} else {
return 'auth fail';
}
這篇關于在laravel 5 中對來自兩個以上表的用戶進行身份驗證的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!