{"id":650,"date":"2023-08-26T07:31:51","date_gmt":"2023-08-26T07:31:51","guid":{"rendered":"https:\/\/www.devopsconsulting.in\/blog\/?p=650"},"modified":"2024-11-14T06:22:57","modified_gmt":"2024-11-14T06:22:57","slug":"create-multiple-authentication-in-laravel","status":"publish","type":"post","link":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/","title":{"rendered":"Create Multiple Authentication in Laravel 9"},"content":{"rendered":"\n<p class=\"wp-block-paragraph\">The main topic of this lesson is laravel 9 multi auth. I want to demonstrate Laravel 9 multiple authentication for you. Laravel 9 will teach you about multiple authentication. It is a straightforward illustration of multiple authentication in Laravel 9 utilizing middleware. Let&#8217;s develop an example of multiple auth middleware using Laravel 9 by following a few simple steps. <\/p>\n\n\n\n<p class=\"wp-block-paragraph\">However, In this example, we will add the following three types of users as below:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">1) User<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">2) operetor<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">3) Admin<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">When we log in as admin then it will redirect on admin routes, If you log in as manager then it will redirect on manager routes.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>follow simple steps:<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Although this is optional, you can still run the command below if you haven&#8217;t yet created the Laravel app:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>composer create-project laravel\/laravel multirole<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 2: Database Configuration<\/strong><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>DB_CONNECTION=mysql\r\nDB_HOST=127.0.0.1\r\nDB_PORT=3306\r\nDB_DATABASE=here your database name(blog)\r\nDB_USERNAME=here database username(root)\r\nDB_PASSWORD=here database password(root)<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 3: Update Migration and Model<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">In this step, we need to add new row &#8220;type&#8221; in users table and model. than we need to run migration. so let&#8217;s change that on both file.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">database\/migrations\/000_create_users_table.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;?php\r\n  \r\nuse Illuminate\\Database\\Migrations\\Migration;\r\nuse Illuminate\\Database\\Schema\\Blueprint;\r\nuse Illuminate\\Support\\Facades\\Schema;\r\n  \r\nreturn new class extends Migration\r\n{\r\n    \/**\r\n     * Run the migrations.\r\n     *\r\n     * @return void\r\n     *\/\r\n    public function up()\r\n    {\r\n        Schema::create('users', function (Blueprint $table) {\r\n            $table->id();\r\n            $table->string('name');\r\n            $table->string('email')->unique();\r\n            $table->timestamp('email_verified_at')->nullable();\r\n            $table->string('password');\r\n            $table->tinyInteger('type')->default(0);\r\n            \/* Users: 0=>User, 1=>Admin, 2=>operetor *\/\r\n            $table->rememberToken();\r\n            $table->timestamps();\r\n        });\r\n    }\r\n  \r\n    \/**\r\n     * Reverse the migrations.\r\n     *\r\n     * @return void\r\n     *\/\r\n    public function down()\r\n    {\r\n        Schema::dropIfExists('users');\r\n    }\r\n};\r\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Now we need to run migration.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>php artisan migrate<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">update User Model as below code:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">app\/Models\/User.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;?php\r\n\r\nnamespace App\\Models;\r\n  \r\nuse Illuminate\\Contracts\\Auth\\MustVerifyEmail;\r\nuse Illuminate\\Database\\Eloquent\\Factories\\HasFactory;\r\nuse Illuminate\\Foundation\\Auth\\User as Authenticatable;\r\nuse Illuminate\\Notifications\\Notifiable;\r\nuse Laravel\\Sanctum\\HasApiTokens;\r\nuse Illuminate\\Database\\Eloquent\\Casts\\Attribute;\r\n  \r\nclass User extends Authenticatable\r\n{\r\n    use HasApiTokens, HasFactory, Notifiable;\r\n  \r\n    \/**\r\n     * The attributes that are mass assignable.\r\n     *\r\n     * @var array\r\n\r\n     *\/\r\n    protected $fillable = &#91;\r\n        'name',\r\n        'email',\r\n        'password',\r\n        'type'\r\n    ];\r\n  \r\n    \/**\r\n     * The attributes that should be hidden for serialization.\r\n     *\r\n     * @var array\r\n\r\n     *\/\r\n    protected $hidden = &#91;\r\n        'password',\r\n        'remember_token',\r\n    ];\r\n  \r\n    \/**\r\n     * The attributes that should be cast.\r\n     *\r\n     * @var array\r\n\r\n     *\/\r\n    protected $casts = &#91;\r\n        'email_verified_at' => 'datetime',\r\n    ];\r\n \r\n    \/**\r\n     * Interact with the user's first name.\r\n     *\r\n     * @param  string  $value\r\n     * @return \\Illuminate\\Database\\Eloquent\\Casts\\Attribute\r\n     *\/\r\n    protected function type(): Attribute\r\n    {\r\n        return new Attribute(\r\n            get: fn ($value) =>  &#91;\"user\", \"admin\", \"operetor\"]&#91;$value],\r\n        );\r\n    }\r\n}<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 4: Create Auth using scaffold<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Laravel 9 UI Package:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>composer require laravel\/ui \r\nphp artisan ui bootstrap --auth \r\nnpm install\r\nnpm run dev\r\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 5: Create UserAccess Middleware<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">This stage calls for the development of user access middleware, which will prevent users from accessing that page. Let&#8217;s write and update some code now.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>php artisan make:middleware UserAccess<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">app\/Http\/middleware\/UserAccess.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;?php\r\n  \r\nnamespace App\\Http\\Middleware;\r\n  \r\nuse Closure;\r\nuse Illuminate\\Http\\Request;\r\n  \r\nclass UserAccess\r\n{\r\n    \/**\r\n     * Handle an incoming request.\r\n     *\r\n     * @param  \\Illuminate\\Http\\Request  $request\r\n     * @param  \\Closure(\\Illuminate\\Http\\Request): (\\Illuminate\\Http\\Response|\\Illuminate\\Http\\RedirectResponse)  $next\r\n     * @return \\Illuminate\\Http\\Response|\\Illuminate\\Http\\RedirectResponse\r\n     *\/\r\n    public function handle(Request $request, Closure $next, $userType)\r\n    {\r\n        if(auth()->user()->type == $userType){\r\n            return $next($request);\r\n        }\r\n          \r\n        return response()->json(&#91;'You do not have permission to access for this page.']);\r\n        \/* return response()->view('errors.check-permission'); *\/\r\n    }\r\n}<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">app\/Http\/Kernel.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>....\r\nprotected $routeMiddleware = &#91;\r\n    'auth' => \\App\\Http\\Middleware\\Authenticate::class,\r\n    'auth.basic' => \\Illuminate\\Auth\\Middleware\\AuthenticateWithBasicAuth::class,\r\n    'bindings' => \\Illuminate\\Routing\\Middleware\\SubstituteBindings::class,\r\n    'cache.headers' => \\Illuminate\\Http\\Middleware\\SetCacheHeaders::class,\r\n    'can' => \\Illuminate\\Auth\\Middleware\\Authorize::class,\r\n    'guest' => \\App\\Http\\Middleware\\RedirectIfAuthenticated::class,\r\n    'signed' => \\Illuminate\\Routing\\Middleware\\ValidateSignature::class,\r\n    'throttle' => \\Illuminate\\Routing\\Middleware\\ThrottleRequests::class,\r\n    'verified' => \\Illuminate\\Auth\\Middleware\\EnsureEmailIsVerified::class,\r\n====================add this code=====================\r\n    'user-access' => \\App\\Http\\Middleware\\UserAccess::class,\r\n];\r\n....\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 6: Create Routes<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Here, we&#8217;ll add the routes group, where you may add new access routes for managers, admins, and users. Update the code now:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">routes\/web.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;?php\r\n  \r\nuse Illuminate\\Support\\Facades\\Route;\r\n  \r\nuse App\\Http\\Controllers\\HomeController;\r\n  \r\n\/*\r\n|--------------------------------------------------------------------------\r\n| Web Routes\r\n|--------------------------------------------------------------------------\r\n|\r\n| Here is where you can register web routes for your application. These\r\n| routes are loaded by the RouteServiceProvider within a group which\r\n| contains the \"web\" middleware group. Now create something great!\r\n|\r\n*\/\r\n  \r\nRoute::get('\/', function () {\r\n    return view('welcome');\r\n});\r\n  \r\nAuth::routes();\r\n  \r\n\/*------------------------------------------\r\n--------------------------------------------\r\nAll Normal Users Routes List\r\n--------------------------------------------\r\n--------------------------------------------*\/\r\nRoute::middleware(&#91;'auth', 'user-access:user'])->group(function () {\r\n  \r\n    Route::get('\/home', &#91;HomeController::class, 'index'])->name('home');\r\n});\r\n  \r\n\/*------------------------------------------\r\n--------------------------------------------\r\nAll Admin Routes List\r\n--------------------------------------------\r\n--------------------------------------------*\/\r\nRoute::middleware(&#91;'auth', 'user-access:admin'])->group(function () {\r\n  \r\n    Route::get('\/admin\/home', &#91;HomeController::class, 'adminHome'])->name('admin.home');\r\n});\r\n  \r\n\/*------------------------------------------\r\n--------------------------------------------\r\nAll Admin Routes List\r\n--------------------------------------------\r\n--------------------------------------------*\/\r\nRoute::middleware(&#91;'auth', 'user-access:operetor'])->group(function () {\r\n  \r\n    Route::get('\/operetor\/home', &#91;HomeController::class, 'operetorHome'])->name('operetor.home');\r\n});\r\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 7: Update Controller<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">app\/Http\/Controllers\/HomeController.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;?php\r\n  \r\nnamespace App\\Http\\Controllers;\r\n \r\nuse Illuminate\\Http\\Request;\r\n  \r\nclass HomeController extends Controller\r\n{\r\n    \/**\r\n     * Create a new controller instance.\r\n     *\r\n     * @return void\r\n     *\/\r\n    public function __construct()\r\n    {\r\n        $this->middleware('auth');\r\n    }\r\n  \r\n    \/**\r\n     * Show the application dashboard.\r\n     *\r\n     * @return \\Illuminate\\Contracts\\Support\\Renderable\r\n     *\/\r\n    public function index()\r\n    {\r\n        return view('home');\r\n    } \r\n  \r\n    \/**\r\n     * Show the application dashboard.\r\n     *\r\n     * @return \\Illuminate\\Contracts\\Support\\Renderable\r\n     *\/\r\n    public function adminHome()\r\n    {\r\n        return view('adminHome');\r\n    }\r\n  \r\n    \/**\r\n     * Show the application dashboard.\r\n     *\r\n     * @return \\Illuminate\\Contracts\\Support\\Renderable\r\n     *\/\r\n    public function operetorHome()\r\n    {\r\n        return view('operetorHome');\r\n    }\r\n}\r\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 8: Create Blade file<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">resources\/views\/home.blade.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>@extends('layouts.app')\r\n  \r\n@section('content')\r\n&lt;div class=\"container\">\r\n    &lt;div class=\"row justify-content-center\">\r\n        &lt;div class=\"col-md-8\">\r\n            &lt;div class=\"card\">\r\n                &lt;div class=\"card-header\">{{ __('Dashboard') }}&lt;\/div>\r\n  \r\n                &lt;div class=\"card-body\">\r\n                    @if (session('status'))\r\n                        &lt;div class=\"alert alert-success\" role=\"alert\">\r\n                            {{ session('status') }}\r\n                        &lt;\/div>\r\n                    @endif\r\n  \r\n                    You are a User.\r\n                &lt;\/div>\r\n            &lt;\/div>\r\n        &lt;\/div>\r\n    &lt;\/div>\r\n&lt;\/div>\r\n@endsection<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">resources\/views\/adminHome.blade.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>@extends('layouts.app')\r\n  \r\n@section('content')\r\n&lt;div class=\"container\">\r\n    &lt;div class=\"row justify-content-center\">\r\n        &lt;div class=\"col-md-8\">\r\n            &lt;div class=\"card\">\r\n                &lt;div class=\"card-header\">{{ __('Dashboard') }}&lt;\/div>\r\n  \r\n                &lt;div class=\"card-body\">\r\n                    You are a Admin User.\r\n                &lt;\/div>\r\n            &lt;\/div>\r\n        &lt;\/div>\r\n    &lt;\/div>\r\n&lt;\/div>\r\n@endsection<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">resources\/views\/operetorHome.blade.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>@extends('layouts.app')\r\n@section('content')\r\n&lt;div class=\"container\">\r\n    &lt;div class=\"row justify-content-center\">\r\n        &lt;div class=\"col-md-8\">\r\n            &lt;div class=\"card\">\r\n                &lt;div class=\"card-header\">{{ __('Dashboard') }}&lt;\/div>\r\n  \r\n                &lt;div class=\"card-body\">\r\n                    You are a operetor User.\r\n                &lt;\/div>\r\n            &lt;\/div>\r\n        &lt;\/div>\r\n    &lt;\/div>\r\n&lt;\/div>\r\n@endsection<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 9: Update on LoginController<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">We will modify the LoginController in this phase so that after a user logs in, we may redirect them based on their access. Admin users are forwarded to the admin route, and normal users are forwarded to the home route. So let&#8217;s alter.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">app\/Http\/Controllers\/Auth\/LoginController.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;?php\r\n  \r\nnamespace App\\Http\\Controllers\\Auth;\r\n  \r\nuse App\\Http\\Controllers\\Controller;\r\nuse App\\Providers\\RouteServiceProvider;\r\nuse Illuminate\\Foundation\\Auth\\AuthenticatesUsers;\r\nuse Illuminate\\Http\\Request;\r\n  \r\nclass LoginController extends Controller\r\n{\r\n    \/*\r\n    |--------------------------------------------------------------------------\r\n    | Login Controller\r\n    |--------------------------------------------------------------------------\r\n    |\r\n    | This controller handles authenticating users for the application and\r\n    | redirecting them to your home screen. The controller uses a trait\r\n    | to conveniently provide its functionality to your applications.\r\n    |\r\n    *\/\r\n  \r\n    use AuthenticatesUsers;\r\n  \r\n    \/**\r\n     * Where to redirect users after login.\r\n     *\r\n     * @var string\r\n     *\/\r\n    protected $redirectTo = RouteServiceProvider::HOME;\r\n  \r\n    \/**\r\n     * Create a new controller instance.\r\n     *\r\n     * @return void\r\n     *\/\r\n    public function __construct()\r\n    {\r\n        $this->middleware('guest')->except('logout');\r\n    }\r\n \r\n    public function login(Request $request)\r\n    {   \r\n        $input = $request->all();\r\n     \r\n        $this->validate($request, &#91;\r\n            'email' => 'required|email',\r\n            'password' => 'required',\r\n        ]);\r\n     \r\n        if(auth()->attempt(array('email' => $input&#91;'email'], 'password' => $input&#91;'password'])))\r\n        {\r\n            if (auth()->user()->type == 'admin') {\r\n                return redirect()->route('admin.home');\r\n            }else if (auth()->user()->type == 'manager') {\r\n                return redirect()->route('manager.home');\r\n            }else{\r\n                return redirect()->route('home');\r\n            }\r\n        }else{\r\n            return redirect()->route('login')\r\n                ->with('error','Email-Address And Password Are Wrong.');\r\n        }\r\n          \r\n    }\r\n}<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Step 10: Create Seeder<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">To create new admin and regular users, we will establish a seeder. Consequently, let&#8217;s construct a seeder with the command:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>php artisan make:seeder CreateUsersSeeder<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">database\/seeders\/CreateUsersSeeder.php<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;?php\r\n  \r\nnamespace Database\\Seeders;\r\n  \r\nuse Illuminate\\Database\\Console\\Seeds\\WithoutModelEvents;\r\nuse Illuminate\\Database\\Seeder;\r\nuse App\\Models\\User;\r\n  \r\nclass CreateUsersSeeder extends Seeder\r\n{\r\n    \/**\r\n     * Run the database seeds.\r\n     *\r\n     * @return void\r\n     *\/\r\n    public function run()\r\n    {\r\n        $users = &#91;\r\n            &#91;\r\n               'name'=>'Admin User',\r\n               'email'=>'admin@motoshare.com',\r\n               'type'=>1,\r\n               'password'=> bcrypt('123456'),\r\n            ],\r\n            &#91;\r\n               'name'=>'operetor User',\r\n               'email'=>'operetor@motoshare.com',\r\n               'type'=> 2,\r\n               'password'=> bcrypt('123456'),\r\n            ],\r\n            &#91;\r\n               'name'=>'User',\r\n               'email'=>'user@motoshare.com',\r\n               'type'=>0,\r\n               'password'=> bcrypt('123456'),\r\n            ],\r\n        ];\r\n    \r\n        foreach ($users as $key => $user) {\r\n            User::create($user);\r\n        }\r\n    }\r\n}<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Now let&#8217;s run seeder:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>php artisan db:seed --class=CreateUsersSeeder<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><strong>Run Laravel App:<\/strong><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>php artisan serve<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Now, Go to your web browser, type the given URL and view the app output:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>Normal User:\nEmail: user@motoshare.com\r\nPassword: 123456<\/code><\/pre>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"646\" height=\"121\" src=\"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png\" alt=\"\" class=\"wp-image-652\" srcset=\"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png 646w, https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image-300x56.png 300w\" sizes=\"auto, (max-width: 646px) 100vw, 646px\" \/><\/figure>\n\n\n\n<pre class=\"wp-block-code\"><code>Admin:\nEmail: admin@motoshare.com\nPassword: 123456<\/code><\/pre>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"646\" height=\"107\" src=\"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image-1.png\" alt=\"\" class=\"wp-image-653\" srcset=\"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image-1.png 646w, https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image-1-300x50.png 300w\" sizes=\"auto, (max-width: 646px) 100vw, 646px\" \/><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\"><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>operator:\nEmail: admin@motoshare.com\nPassword: 123456<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>The main topic of this lesson is laravel 9 multi auth. I want to demonstrate Laravel 9 multiple authentication for you. Laravel 9 will teach you about&#8230; <\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[87],"tags":[128,126],"class_list":["post-650","post","type-post","status-publish","format-standard","hentry","category-laravel","tag-create-multi-role-authentication-in-laravel-9","tag-create-multiple-authentication-in-laravel"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.7 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Create Multiple Authentication in Laravel 9 - DevOps Consulting<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Create Multiple Authentication in Laravel 9 - DevOps Consulting\" \/>\n<meta property=\"og:description\" content=\"The main topic of this lesson is laravel 9 multi auth. I want to demonstrate Laravel 9 multiple authentication for you. Laravel 9 will teach you about...\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/\" \/>\n<meta property=\"og:site_name\" content=\"DevOps Consulting\" \/>\n<meta property=\"article:published_time\" content=\"2023-08-26T07:31:51+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-11-14T06:22:57+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png\" \/>\n<meta name=\"author\" content=\"Abhishek Singh\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Abhishek Singh\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/\"},\"author\":{\"name\":\"Abhishek Singh\",\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/#\\\/schema\\\/person\\\/fc397ba8be42f9fdd53450edfc73006f\"},\"headline\":\"Create Multiple Authentication in Laravel 9\",\"datePublished\":\"2023-08-26T07:31:51+00:00\",\"dateModified\":\"2024-11-14T06:22:57+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/\"},\"wordCount\":394,\"commentCount\":1,\"image\":{\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/wp-content\\\/uploads\\\/2023\\\/08\\\/image.png\",\"keywords\":[\"Create Multi role Authentication in Laravel 9\",\"Create Multiple Authentication in Laravel\"],\"articleSection\":[\"Laravel\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/\",\"url\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/\",\"name\":\"Create Multiple Authentication in Laravel 9 - DevOps Consulting\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/wp-content\\\/uploads\\\/2023\\\/08\\\/image.png\",\"datePublished\":\"2023-08-26T07:31:51+00:00\",\"dateModified\":\"2024-11-14T06:22:57+00:00\",\"author\":{\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/#\\\/schema\\\/person\\\/fc397ba8be42f9fdd53450edfc73006f\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/create-multiple-authentication-in-laravel\\\/#primaryimage\",\"url\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/wp-content\\\/uploads\\\/2023\\\/08\\\/image.png\",\"contentUrl\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/wp-content\\\/uploads\\\/2023\\\/08\\\/image.png\",\"width\":646,\"height\":121},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/\",\"name\":\"DevOps Consulting\",\"description\":\"DevOps Consulting | SRE Consulting | DevSecOps Consulting | MLOps Consulting\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/#\\\/schema\\\/person\\\/fc397ba8be42f9fdd53450edfc73006f\",\"name\":\"Abhishek Singh\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/790feefe779852cdf344ca7318bf6c13832223c9b3c6bf4d217658412041026d?s=96&d=mm&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/790feefe779852cdf344ca7318bf6c13832223c9b3c6bf4d217658412041026d?s=96&d=mm&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/790feefe779852cdf344ca7318bf6c13832223c9b3c6bf4d217658412041026d?s=96&d=mm&r=g\",\"caption\":\"Abhishek Singh\"},\"description\":\"I\u2019m Abhishek, a DevOps, SRE, DevSecOps, and Cloud expert with a passion for sharing knowledge and real-world experiences. I\u2019ve had the opportunity to work with Cotocus and continue to contribute to multiple platforms where I share insights across different domains: \u2022 DevOps School \u2013 Tech blogs and tutorials \u2022 Holiday Landmark \u2013 Travel stories and guides \u2022 Stocks Mantra \u2013 Stock market strategies and tips \u2022 My Medic Plus \u2013 Health and fitness guidance \u2022 TrueReviewNow \u2013 Honest product reviews \u2022 Wizbrand \u2013 SEO and digital tools for businesses I\u2019m also exploring the fascinating world of Quantum Computing.\",\"url\":\"https:\\\/\\\/www.devopsconsulting.in\\\/blog\\\/author\\\/abhishek\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Create Multiple Authentication in Laravel 9 - DevOps Consulting","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/","og_locale":"en_US","og_type":"article","og_title":"Create Multiple Authentication in Laravel 9 - DevOps Consulting","og_description":"The main topic of this lesson is laravel 9 multi auth. I want to demonstrate Laravel 9 multiple authentication for you. Laravel 9 will teach you about...","og_url":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/","og_site_name":"DevOps Consulting","article_published_time":"2023-08-26T07:31:51+00:00","article_modified_time":"2024-11-14T06:22:57+00:00","og_image":[{"url":"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png","type":"","width":"","height":""}],"author":"Abhishek Singh","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Abhishek Singh","Est. reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/#article","isPartOf":{"@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/"},"author":{"name":"Abhishek Singh","@id":"https:\/\/www.devopsconsulting.in\/blog\/#\/schema\/person\/fc397ba8be42f9fdd53450edfc73006f"},"headline":"Create Multiple Authentication in Laravel 9","datePublished":"2023-08-26T07:31:51+00:00","dateModified":"2024-11-14T06:22:57+00:00","mainEntityOfPage":{"@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/"},"wordCount":394,"commentCount":1,"image":{"@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/#primaryimage"},"thumbnailUrl":"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png","keywords":["Create Multi role Authentication in Laravel 9","Create Multiple Authentication in Laravel"],"articleSection":["Laravel"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/","url":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/","name":"Create Multiple Authentication in Laravel 9 - DevOps Consulting","isPartOf":{"@id":"https:\/\/www.devopsconsulting.in\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/#primaryimage"},"image":{"@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/#primaryimage"},"thumbnailUrl":"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png","datePublished":"2023-08-26T07:31:51+00:00","dateModified":"2024-11-14T06:22:57+00:00","author":{"@id":"https:\/\/www.devopsconsulting.in\/blog\/#\/schema\/person\/fc397ba8be42f9fdd53450edfc73006f"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.devopsconsulting.in\/blog\/create-multiple-authentication-in-laravel\/#primaryimage","url":"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png","contentUrl":"https:\/\/www.devopsconsulting.in\/blog\/wp-content\/uploads\/2023\/08\/image.png","width":646,"height":121},{"@type":"WebSite","@id":"https:\/\/www.devopsconsulting.in\/blog\/#website","url":"https:\/\/www.devopsconsulting.in\/blog\/","name":"DevOps Consulting","description":"DevOps Consulting | SRE Consulting | DevSecOps Consulting | MLOps Consulting","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.devopsconsulting.in\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/www.devopsconsulting.in\/blog\/#\/schema\/person\/fc397ba8be42f9fdd53450edfc73006f","name":"Abhishek Singh","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/790feefe779852cdf344ca7318bf6c13832223c9b3c6bf4d217658412041026d?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/790feefe779852cdf344ca7318bf6c13832223c9b3c6bf4d217658412041026d?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/790feefe779852cdf344ca7318bf6c13832223c9b3c6bf4d217658412041026d?s=96&d=mm&r=g","caption":"Abhishek Singh"},"description":"I\u2019m Abhishek, a DevOps, SRE, DevSecOps, and Cloud expert with a passion for sharing knowledge and real-world experiences. I\u2019ve had the opportunity to work with Cotocus and continue to contribute to multiple platforms where I share insights across different domains: \u2022 DevOps School \u2013 Tech blogs and tutorials \u2022 Holiday Landmark \u2013 Travel stories and guides \u2022 Stocks Mantra \u2013 Stock market strategies and tips \u2022 My Medic Plus \u2013 Health and fitness guidance \u2022 TrueReviewNow \u2013 Honest product reviews \u2022 Wizbrand \u2013 SEO and digital tools for businesses I\u2019m also exploring the fascinating world of Quantum Computing.","url":"https:\/\/www.devopsconsulting.in\/blog\/author\/abhishek\/"}]}},"_links":{"self":[{"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/posts\/650","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/comments?post=650"}],"version-history":[{"count":2,"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/posts\/650\/revisions"}],"predecessor-version":[{"id":654,"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/posts\/650\/revisions\/654"}],"wp:attachment":[{"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/media?parent=650"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/categories?post=650"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.devopsconsulting.in\/blog\/wp-json\/wp\/v2\/tags?post=650"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}