从 laravel 5 中的两个以上的表中验证用户
Authenticate users from more than two tables in laravel 5
据我所知,Auth::attempt
用于验证来自 users
table 的用户,但我想验证来自 managers
table 和管理员的其他用户来自 admins
table。我知道 laravel-multiauth
插件已经存在。但是我们可以创建自己的 AuthServiceProvider
来验证来自多个 tables.. 的用户吗?
如果你想试试我的想法。我期待不同的 table
有不同的 users
。因为如果你在其他 table 中有相同的 user
,它将无法工作。
- 选择您的优先级table(例如用户)
- 添加条件
if(Auth::user(attempt(...))
elseif(Auth::manager(attempt(...))
elseif(Auth::admins(attempt(...)))
注意:这里你的优先级table是users
,那么如果用户不存在那个table,它会尝试managers
table,那么如果仍然不存在,它会检查admins
table,否则(使用else
)return一个消息错误。
其他选项:
其他选项是使用此包 sarav/laravel-multiauth
。你可以关注这个线程。 获取更多信息。
更多参考:
https://laracasts.com/discuss/channels/laravel/52-auth-multiple-tables?page=1
您可以设置多个身份验证守卫,每个都有不同的提供者。提供商定义要使用的 table 或模型。
在 config/auth.php
中,您按如下方式设置 providers
并且还为每个提供商设置相应的 guards
:
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\User::class,
],
'managers' => [
'driver' => 'eloquent',
'model' => App\Manager::class,
],
'admins' => [
'driver' => 'eloquent',
'model' => App\Admin::class,
]
]
然后你可以这样验证:
Auth::attempt($credentials) // use default guard for simple users
Auth::guard('manager')->attempt($credentials)
Auth::guard('admin')->attempt($credentials)
查看文档 here。
为经理 table 和管理员 table 创建模型。此模型应扩展 Illuminate\Foundation\Auth\User
在config/auth.php
,
添加到供应商数组:
'managers' => [
'driver' => 'eloquent',
'model' => App\Manager::class,
],
添加到守卫数组:
'web_manager' => [
'driver' => 'session',
'provider' => 'managers',
],
然后。在 LoginController
中(使用 php artisan make:auth
为经理创建一个)使用特征 Illuminate\Foundation\Auth\AuthenticatesUsers
和
覆盖守卫和重定向属性。
protected $redirectTo = 'redirect_path_after_manager_login';
protected function guard()
{
return Auth::guard('web_manager');
}
manager模型通过认证,您可以获取经过认证的manager对象Auth::guard('web_manager')->user();
首先在 Illuminate\Foundation\Auth
中创建 Admin Authenticatable 就像
<?php
namespace Illuminate\Foundation\Auth;
use Illuminate\Auth\Authenticatable;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Auth\Passwords\CanResetPassword;
use Illuminate\Foundation\Auth\Access\Authorizable;
use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract;
use Illuminate\Contracts\Auth\Access\Authorizable as AuthorizableContract;
use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract;
class Admin extends Model implements
AuthenticatableContract,
AuthorizableContract,
CanResetPasswordContract
{
use Authenticatable, Authorizable, CanResetPassword;
}
然后通过扩展 Authenticatable
管理模型创建管理模型 :-
<?php
namespace App;
use Illuminate\Foundation\Auth\Admin 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
如下
添加 providers array
'admins' => [
'driver' => 'eloquent',
'model' => App\Admin::class,
],
并添加到guards数组中。
'user' => [
'driver' => 'session',
'provider' => 'users',
],
'admin' => [
'driver' => 'session',
'provider' => 'admins',
],
现在从 用户 table
进行身份验证
if (Auth::guard('user')->attempt(['email' => $email, 'password' => $password])) {
$details = Auth::guard('user')->user();
$user = $details['original'];
return $user;
} else {
return 'auth fail';
}
并从 Admin table
进行身份验证
if (Auth::guard('admin')->attempt(['email' => $email, 'password' => $password])) {
$details = Auth::guard('admin')->user();
$user = $details['original'];
return $user;
} else {
return 'auth fail';
}
据我所知,Auth::attempt
用于验证来自 users
table 的用户,但我想验证来自 managers
table 和管理员的其他用户来自 admins
table。我知道 laravel-multiauth
插件已经存在。但是我们可以创建自己的 AuthServiceProvider
来验证来自多个 tables.. 的用户吗?
如果你想试试我的想法。我期待不同的 table
有不同的 users
。因为如果你在其他 table 中有相同的 user
,它将无法工作。
- 选择您的优先级table(例如用户)
- 添加条件
if(Auth::user(attempt(...))
elseif(Auth::manager(attempt(...))
elseif(Auth::admins(attempt(...)))
注意:这里你的优先级table是users
,那么如果用户不存在那个table,它会尝试managers
table,那么如果仍然不存在,它会检查admins
table,否则(使用else
)return一个消息错误。
其他选项:
其他选项是使用此包 sarav/laravel-multiauth
。你可以关注这个线程。
更多参考:
https://laracasts.com/discuss/channels/laravel/52-auth-multiple-tables?page=1
您可以设置多个身份验证守卫,每个都有不同的提供者。提供商定义要使用的 table 或模型。
在 config/auth.php
中,您按如下方式设置 providers
并且还为每个提供商设置相应的 guards
:
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\User::class,
],
'managers' => [
'driver' => 'eloquent',
'model' => App\Manager::class,
],
'admins' => [
'driver' => 'eloquent',
'model' => App\Admin::class,
]
]
然后你可以这样验证:
Auth::attempt($credentials) // use default guard for simple users
Auth::guard('manager')->attempt($credentials)
Auth::guard('admin')->attempt($credentials)
查看文档 here。
为经理 table 和管理员 table 创建模型。此模型应扩展 Illuminate\Foundation\Auth\User
在config/auth.php
,
添加到供应商数组:
'managers' => [
'driver' => 'eloquent',
'model' => App\Manager::class,
],
添加到守卫数组:
'web_manager' => [
'driver' => 'session',
'provider' => 'managers',
],
然后。在 LoginController
中(使用 php artisan make:auth
为经理创建一个)使用特征 Illuminate\Foundation\Auth\AuthenticatesUsers
和
覆盖守卫和重定向属性。
protected $redirectTo = 'redirect_path_after_manager_login';
protected function guard()
{
return Auth::guard('web_manager');
}
manager模型通过认证,您可以获取经过认证的manager对象Auth::guard('web_manager')->user();
首先在 Illuminate\Foundation\Auth
中创建 Admin Authenticatable 就像
<?php
namespace Illuminate\Foundation\Auth;
use Illuminate\Auth\Authenticatable;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Auth\Passwords\CanResetPassword;
use Illuminate\Foundation\Auth\Access\Authorizable;
use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract;
use Illuminate\Contracts\Auth\Access\Authorizable as AuthorizableContract;
use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract;
class Admin extends Model implements
AuthenticatableContract,
AuthorizableContract,
CanResetPasswordContract
{
use Authenticatable, Authorizable, CanResetPassword;
}
然后通过扩展 Authenticatable
管理模型创建管理模型 :-
<?php
namespace App;
use Illuminate\Foundation\Auth\Admin 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
如下
添加 providers array
'admins' => [
'driver' => 'eloquent',
'model' => App\Admin::class,
],
并添加到guards数组中。
'user' => [
'driver' => 'session',
'provider' => 'users',
],
'admin' => [
'driver' => 'session',
'provider' => 'admins',
],
现在从 用户 table
进行身份验证 if (Auth::guard('user')->attempt(['email' => $email, 'password' => $password])) {
$details = Auth::guard('user')->user();
$user = $details['original'];
return $user;
} else {
return 'auth fail';
}
并从 Admin table
进行身份验证 if (Auth::guard('admin')->attempt(['email' => $email, 'password' => $password])) {
$details = Auth::guard('admin')->user();
$user = $details['original'];
return $user;
} else {
return 'auth fail';
}