【问题标题】:Two different models for authentication in laravel 5.4laravel 5.4 中两种不同的身份验证模型
【发布时间】:2018-04-17 21:26:48
【问题描述】:

假设我有两个不同的模型和表,分别命名为 usercompany

如您所知,laravel 使用User 模型来管理身份验证。但因为我有两个不同的模型,我想要可以分别管理它们。

我正在使用 laravel 5.4,但我不知道该怎么做。

【问题讨论】:

    标签: php laravel laravel-5.4


    【解决方案1】:

    如果你说的是多重身份验证系统,那么你必须创建多个守卫来实现。

    同样的问题有很好的答案。

    Can anyone explain Laravel 5.2 Multi Auth with example

    它在 Laravel 5.2 上,但它可以在 Laravel 5.4 上轻松实现。

    1. 创建一个模型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',
          ];
      
      }
      
    2. 为模型 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);
    
    1. 现在为公司 App\Http\Controllers\Auth\CompanyLoginController 创建与 Auth\LoginController 相同的 Auth 控制器。 指定 $redirectToguard

      //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 视图与用户的登录表单相同。

    1. 现在创建路线

      //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');
      });
      
    2. 为公司创建中间件

      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=iKRLrJXNN4Mexpertphp.in/article/…
    • 用必要的步骤更新了答案。是的,这也是一个很长的答案。大声笑
    • @abid-reza,如果我想通过Auth::user()访问登录用户呢?在这种情况下,我必须在很多情况下为普通用户检查 Auth::user() 或为公司用户检查 Auth::guard('company')->user() ,对吗?
    • 抱歉回复晚了。我检查了,在 config/auth.php 中,你可以在 defaults 数组中看到,gaurd => 'web' 就在那里。所以你必须使用 Auth::guard('company')->user() 来获取公司用户。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-02-05
    • 1970-01-01
    • 1970-01-01
    • 2017-12-24
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多