clock  Mon - Sun 8.00 AM - 8.00 PM
fb
instagram
play store
pinterest

Multiple Authentication in Laravel

writter  Sumit Dey Sarkar
Date  22 Mar 2023
Language  Laravel
Multiple Authentication in Laravel

Multiple Authentication in Laravel

Laravel, a popular PHP web framework, provides built-in support for multiple authentication systems. This allows developers to create separate authentication systems for different types of users, such as admins and regular users.

 

Multiple Authentication in Laravel

Here's how to implement multiple authentication in Laravel:

 

Step 1 - Create the authentication guards: In Laravel, guards are used to authenticate users for each type of authentication. You can create a guard for each authentication system by adding a new entry to the guards array in config/auth.php. For example, you could create a guard called "admin" for the admin authentication system:

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],

    'admin' => [
        'driver' => 'session',
        'provider' => 'admins',
    ],
],

 

Step 2 - Create the authentication providers: Providers are used to retrieve user information for authentication. You can create a provider for each authentication system by adding a new entry to the providers array in config/auth.php. For example, you could create a provider called "admins" for the admin authentication system:

'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => App\Models\User::class,
    ],

    'admins' => [
        'driver' => 'eloquent',
        'model' => App\Models\Admin::class,
    ],
],

 

Step 3 - Implement authentication: Now you can use the guard and provider you created to authenticate users. You can specify the guard to use when logging in and out by adding the guard name as the second argument to the Auth::attempt and Auth::logout methods. For example, to log in an admin user:

if (Auth::guard('admin')->attempt($credentials)) {
    // Authentication passed...
    return redirect()->intended('dashboard');
}

 

Step 4 -  Protect routes: To protect routes based on the user type, you can use the middleware provided by Laravel. For example, to protect a route so that only authenticated admin users can access it:

Route::get('/dashboard', function () {
    // Only authenticated admin users may enter...
})->middleware('auth:admin');

 

By following these steps, you can implement multiple authentication systems in Laravel.

Comments 0

Leave a comment

Coursera, Codeacademy, Udacity, W3Schools, Udemy, Alison, TheNewBoston, edX, P.S.Codewars,Freecodecamp, Managing technical debt blog, Scrimba, Codepen, Codepen/challenges, The Odin Project, htmlreference.​io, cssreference.​io, Frontend Mentor, Dev Challenges, MDN, Code Mentor, Coding Dojo, CSS Battle, Codier, Ace Frontend, Can I Use, CSS Tricks, 30 Seconds of Code,tutorialspoint, Neumorphism, Shaddows Brumm, Fancy Border Radius, Glow Generator, Clothoid Corners, Glassmorphism, Clipy, CSS Filters, Base64 Image, Quantity Queries, Animations, Cubic-Bezier, Keyframes, Wait Animate, Transition.Style, graphic design, web design, website design, website builder, web developer, web designer, webdesign, ecommerce website, web design company, website creator, website designer, responsive web design, web development company, best website design, web design software, web page design, build a website, web developer salary, design website, web design courses, how to design a website, web design inspiration, website layout, web designer salary, web application development, ecommerce website design, web agency, software development company, web design tutorial, web programming, design company, website design templates, what is web designing, web developer jobs, website developer, web design agency, freelance web developer, web design services, freelance web designer, graphic design websites, web solutions, ecommerce website development, free website design, web development courses, webdev, web developers, web development tools, website design services, developpeur web, web design london, website design ideas, web designing and programming, design a website, web design and development, web dev, web development services, homepage design, best designed websites, cheap website design, learn web design, web design templates, web design tools, web design jobs, website design inspiration, web design india, flash website, website developers, designer websites, website services, website design cost, good website design, site design, simple website design, cool website designs, modern website design, graphic designer websites, webcode, best web design software, website making, free web design software, mobile website design, learn web development, front end web developer, how to become a web developer, web developer portfolio, web development company in india, python web development, web development tutorial, website company, website design and development, web company, webdesigning, professional website design, affordable web design, best web design company, creative web design, top website designs, website design pricing, web developer tools, how to develop a website