laravel 5.4 中两种不同的身份验证模型
Posted
技术标签:
【中文标题】laravel 5.4 中两种不同的身份验证模型【英文标题】:Two different models for authentication in laravel 5.4 【发布时间】:2018-04-17 21:26:48 【问题描述】:假设我有两个不同的模型和表,分别命名为 user
和 company
。
如您所知,laravel 使用User
模型来管理身份验证。但因为我有两个不同的模型,我想要可以分别管理它们。
我正在使用 laravel 5.4,但我不知道该怎么做。
【问题讨论】:
【参考方案1】:如果你说的是多重身份验证系统,那么你必须创建多个守卫来实现。
同样的问题有很好的答案。
Can anyone explain Laravel 5.2 Multi Auth with example
它在 Laravel 5.2 上,但它可以在 Laravel 5.4 上轻松实现。
创建一个模型App\Company,它扩展了Authenticatable Class。该模型将作为用户模型工作,它将公司保护(在下一步中)
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class Company extends Authenticatable
use Notifiable;
/**
* 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',
];
为模型 App\Company 创建一个守卫和提供者。
// Authenticating guards and providers
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'users',
],
'api' => [
'driver' => 'token',
'provider' => 'users',
],
'company' => [
'driver' => 'session',
'provider' => 'company',
],
],
// Providers
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\User::class,
],
'company' => [
'driver' => 'eloquent',
'model' => App\Company::class,
]
],
现在你可以根据不同的守卫找到用户了。
$user = Auth::guard('company')->user();
// Or...
$user = auth()->guard('company')->user();
dd($user);
现在为公司 App\Http\Controllers\Auth\CompanyLoginController 创建与 Auth\LoginController 相同的 Auth 控制器。 指定 $redirectTo 和 guard
//Auth\ComapnyLoginController.php
protected $redirectTo = '/comapany';
protected $guard = 'comapany';
public function showLoginForm()
if (view()->exists('auth.authenticate'))
return view('auth.authenticate');
return view('comapany.auth.login');
现在为用户创建登录表单 - company.auth.login 视图与用户的登录表单相同。
现在创建路线
//Login Routes...
Route::group(['prefix'=>'company', 'middleware'=>'company'], function()
Route::get('/login','Auth\CompanyLoginController@showLoginForm');
Route::post('/login','Auth\CompanyLoginController@login');
// ...
// rest of the company dashboard and other links
// ...
Route::get('/logout','Auth\CompanyLoginController@logout');
);
为公司创建中间件
class RedirectIfNotCompany
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @param string|null $guard
* @return mixed
*/
public function handle($request, Closure $next, $guard = 'company')
if (!Auth::guard($guard)->check())
return redirect('/');
return $next($request);
并将其注册到kernal.php
protected $routeMiddleware = [
'company' => \App\Http\Middleware\RedirectIfNotCompany::class,
];
这就是你所需要的。 通过guard名称访问用户
Auth::guard('company')->user()
【讨论】:
如果你知道我如何在 laravel 5.4 中做到这一点,请指导我。建议链接中描述的解决方案很长并且有很多配置。 我想要,但答案完全相同。只要在给定的答案中,它将是相同的。我会尝试用简短的步骤来解释它,但是这里有一些教程链接 youtube.com/watch?v=iKRLrJXNN4M 和 expertphp.in/article/… 用必要的步骤更新了答案。是的,这也是一个很长的答案。大声笑 @abid-reza,如果我想通过Auth::user()
访问登录用户呢?在这种情况下,我必须在很多情况下为普通用户检查 Auth::user()
或为公司用户检查 Auth::guard('company')->user()
,对吗?
抱歉回复晚了。我检查了,在 config/auth.php 中,你可以在 defaults 数组中看到,gaurd => 'web' 就在那里。所以你必须使用 Auth::guard('company')->user() 来获取公司用户。以上是关于laravel 5.4 中两种不同的身份验证模型的主要内容,如果未能解决你的问题,请参考以下文章
Laravel 5.4 + Ajax 等于 401 未经身份验证
如果用户未使用中间件进行身份验证,Laravel 5.4 将重定向到特定页面
Laravel 5.4:在两个表上具有多重身份验证的 JWT API 一个有效,另一个无效
laravel 5.4 使用 ajax 登录。身份验证成功,但 redirectTo 属性不起作用并保持重定向到“/home”