Home > Backend Development > PHP Tutorial > How to set up multiple authentication in Laravel 5.6

How to set up multiple authentication in Laravel 5.6

藏色散人
Release: 2023-04-04 20:00:02
Original
3519 people have browsed it

In this article, we will cover multiple authentication in Laravel 5.6. Multiple authentication here is just the process of authenticating against multiple user models.

How to set up multiple authentication in Laravel 5.6

#In the following sections, we will demonstrate Laravel’s built-in authentication capabilities. More specifically, I'll show you how to authenticate both an admin user and a normal user.

Step 1: Laravel Setup

Set up the Laravel project using composer.

composer create-project --prefer-dist laravel/laravel project-name
Copy after login

Step 2: Database Configuration

Open the .env file and set the database credentials in the file.

DB_DATABASE= database-name
DB_USERNAME= root
DB_PASSWORD= database-password
Copy after login

Step 3: Authentication

To register and log in using Laravel’s built-in authentication system, just run the following command:

php artisan make:auth
Copy after login

Step 4: Set up models and migrations

Create and set up models and migrations for Admin:

php artisan make:model Admin -m
Copy after login

To set up models for Admin, go to app/ Admin.php and update the code with the following code:

/**
 * Remove 'use Illuminate\Database\Eloquent\Model;'
 */
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class Admin extends Authenticatable
{
    use Notifiable;
// The authentication guard for admin
    protected $guard = 'admin';
     /**
      * The attributes that are mass assignable.
      *
      * @var array
      */
    protected $fillable = [
        'email', 'password',
    ];
     /**
      * The attributes that should be hidden for arrays.
      *
      * @var array
      */
    protected $hidden = [
        'password', 'remember_token',
    ];
Copy after login

To set up the migration table for Admin, go to database/migration/***_create_admins_table.php and update the code with the following code:

//
{
    Schema::create('admins', function (Blueprint $table) {
            $table->increments('id');
            $table->string('email')->unique();
            $table->string('password');
            $table->rememberToken();
            $table->timestamps();
    });
 }
//
Copy after login

Step 5: Set up the Admin Controller

To create a controller for Admin, run the following command:

php artisan make:controller AdminController
Copy after login

To set up the controller, go to app/Http/Controllers/AdminController.php and update the code with the following code:

class AdminController extends Controller{    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {        $this->middleware('auth:admin');
    }
    /**
     * Show the application dashboard.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {        return view('admin');
    }}
Copy after login

Step 6: Set up the login controller for the admin user

To create the Login controller, run the following command:

php artisan make:controller Auth/AdminLoginController
Copy after login

To set up the login controller, go to app/Http/Controllers/Auth/AdminLoginController.php and update the code with the following code:

use Illuminate\Http\Request;use App\Http\Controllers\Controller;use Illuminate\Foundation\Auth\AuthenticatesUsers;use Illuminate\Support\Facades\Auth;class AdminLoginController extends Controller{    /**
     * Show the application’s login form.
     *
     * @return \Illuminate\Http\Response
     */
    public function showLoginForm()
    {        return view(’auth.admin-login’);
    }
    protected function guard(){        return Auth::guard('admin');
    }
    
    use AuthenticatesUsers;    /**
     * Where to redirect users after login.
     *
     * @var string
     */
    protected $redirectTo = '/admin/dashboard';    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {        $this->middleware('guest:admin')->except('logout');
    }}
Copy after login

Step 7: Set up the login controller for normal users

To set up the login controller for normal users, go to app/Http/Controllers/Auth/LoginController.php and update with the following code Code:

///**
 * Show the application's login form.
 *
 * @return \Illuminate\Http\Response
 */public function showLoginForm(){    return view('auth.login');}//
Copy after login

Step 8: Set up login view for Admin

To create and set up login view for Admin, go to resources/views/auth/ and Create a new file admin-login.blade.php. Copy the code from resources/views/auth/login.blade.php and paste it into a new file.

Now update the new file with the following content:

// 
<div class="card-header">{{ __(&#39;Admin Login&#39;) }}</div>
<div class="card-body">
  <form method="POST" action="{{ route(&#39;admin.login.submit&#39;) }}">
//
Copy after login

Step 9: Set the Admin’s Home View

To create and set the home view for Admin views, go to resources/views/ and create a new file admin-home.blade.php. Copy the code in resources/views/home.blade.php and paste it into a new file.

Now update the new file with the following content:

// 
<div class="card">
   <div class="card-header">Admin Dashboard</div>
//
Copy after login

Step 10: Set up Web Application Routing

To set up Web for your application Routes, go to routes/web.php and update your code with the following code:

//
Route::get(&#39;/&#39;, function () {
    return view(&#39;layouts.app&#39;);
});
Route::prefix(&#39;admin&#39;)->group(function() {
    Route::get(&#39;/login&#39;, &#39;Auth\AdminLoginController@showLoginForm&#39;)->name(&#39;admin.login&#39;);
    Route::post(&#39;/login&#39;, &#39;Auth\AdminLoginController@login&#39;)->name(&#39;admin.login.submit&#39;);
    Route::get(&#39;/home&#39;, &#39;AdminController@index&#39;)->name(&#39;admin.home&#39;);
});
//
Copy after login

Step 11: Set up the exception handler

To set up the exception handler, Please go to app/Exceptions/Hanler.php and update the code with the following code:

//
use Illuminate\Auth\AuthenticationException;
//
//
protected $dontReport = [
     \Illuminate\Auth\AuthenticationException::class,
     \Illuminate\Auth\Access\AuthorizationException::class,
     \Symfony\Component\HttpKernel\Exception\HttpException::class,
     \Illuminate\Database\Eloquent\ModelNotFoundException::class,
     \Illuminate\Session\TokenMismatchException::class,
     \Illuminate\Validation\ValidationException::class,
];
//
//
public function render($request, Exception $exception)
{
    return parent::render($request, $exception);
}
    /**
     * Convert an authentication exception into an unauthenticated response.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Illuminate\Auth\AuthenticationException  $exception
     * @return \Illuminate\Http\Response
     */
 protected function unauthenticated($request, AuthenticationException $exception)
 {
    if ($request->expectsJson()) {
     return response()->json([&#39;error&#39; => &#39;Unauthenticated.&#39;],401);
    }
     $guard = array_get($exception->guards(), 0);
      switch ($guard) {
        case &#39;admin&#39;: $login = &#39;admin.login&#39;;
        break;
        default: $login = &#39;login&#39;;
        break;
      }
        return redirect()->guest(route($login));
  }
Copy after login

Step 12: Set up redirect middleware

To be used after authentication To set up the redirect middleware, go to app/Http/Middleware/RedirectIfAuthenticated.php and update the code with the following code:

//
public function handle($request, Closure $next, $guard = null)
{
        switch ($guard) {
            case &#39;admin&#39; :
                if (Auth::guard($guard)->check()) {
                    return redirect()->route(&#39;admin.home&#39;);
                }
                break;
            default:
                if (Auth::guard($guard)->check()) {
                    return redirect()->route(&#39;home&#39;);
                }
                break;
        }
     return $next($request);
}
//
Copy after login

Step 13: Set up the authentication configuration

To set up the authentication configuration, go to config/auth.php and update the code with the following code:

//
&#39;defaults&#39; => [
        &#39;guard&#39; => &#39;web&#39;,
        &#39;passwords&#39; => &#39;users&#39;,
    ],
&#39;admins&#39; => [
        &#39;driver&#39; => &#39;eloquent&#39;,
        &#39;model&#39; => App\Admin::class,
    ],
//
//
&#39;guards&#39; => [
        &#39;web&#39; => [
            &#39;driver&#39; => &#39;session&#39;,
            &#39;provider&#39; => &#39;users&#39;,
        ],
        &#39;api&#39; => [
            &#39;driver&#39; => &#39;token&#39;,
            &#39;provider&#39; => &#39;users&#39;,
        ],
        &#39;admin&#39; => [
            &#39;driver&#39; => &#39;session&#39;,
            &#39;provider&#39; => &#39;admins&#39;,
        ],
        &#39;admin-api&#39; => [
            &#39;driver&#39; => &#39;token&#39;,
            &#39;provider&#39; => &#39;admins&#39;,
        ],
    ],
//
//
&#39;providers&#39; => [
        &#39;users&#39; => [
            &#39;driver&#39; => &#39;eloquent&#39;,
            &#39;model&#39; => App\User::class,
        ],
       &#39;admins&#39; => [
            &#39;driver&#39; => &#39;eloquent&#39;,
            &#39;model&#39; => App\Admin::class,
        ],
    ],
//
//
&#39;passwords&#39; => [
        &#39;users&#39; => [
            &#39;provider&#39; => &#39;users&#39;,
            &#39;table&#39; => &#39;password_resets&#39;,
            &#39;expire&#39; => 60,
        ],
        &#39;admins&#39; => [
            &#39;provider&#39; => &#39;admins&#39;,
            &#39;table&#39; => &#39;password_resets&#39;,
            &#39;expire&#39; => 15,
        ],
    ],
Copy after login

Step 14: Set Database Migration Default String Lenth

To set the default string length for database migrations, go to app/Providers/AppServiceProvider.php and update the code with the following code:

use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\Schema;

//

public function boot(){
    Schema::defaultStringLength(191);
}
Copy after login

Step 15: Run the migration

To run the migration, enter the following command:

php artisan migrate
Copy after login

Use the patch to enter the admin login credentials:

php artisan tinker

$admin = new App\Admin
$admin->email = &#39;admin@app.com&#39;
$admin->password = Hash::make(’admin-password’)
$admin->save()
Copy after login

Hopefully you can now easily set up multiple identities in your Laravel project verify.

The above is the detailed content of How to set up multiple authentication in Laravel 5.6. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template