Laravel Multiple Role handling with Authentication + Authorization

Jerin Monish
May 15, 2019 · 2 min read

Hi, i am new to Laravel and as of my knowledge i have tried to Create a basic laravel application with default Laravel’s Registration, Login/Logout. But interms of Roles i have created three roles like:-

  1. Admin
  2. Teacher
  3. Student

Where all these roles will work with authentication + authorization, Like say suppose you have logged in as a Student and when you try to access teacher’s functionality or URL. It will restrict So, I have done this using Middleware, Routes in Laravel Below i am giving a brief Explanation.

  1. Install Laravel more info(
  2. Next open command prompt where you have installed your Laravel Project and type Composer Update. So that if any of your package was not installed during laravel installation, it will get installed.
  3. Now copy .env.example to .env and generate key for Laravel (php artisan key:generate). So it would have generated key. Also update your Database Name, Username, Password. And check whether your app is working. Assuming you have created Database.
  4. Now add a column in user’s migration table (Located in database/migrations/2014_10_12_000000_create_users_table.php) like user_role with enum datatype with values like admin,student,teacher and migrate.
  5. Now create 3 middlewares and 3 controllers like AdminMiddleware, StudentMiddleware, TeacherMiddleware, Controllers like AdminController, StudentController, TeacherController.

6. Next in your Routes create route by middleware grouping and write the route inside each grouped route say for example:-

Route::group([‘middleware’ => ‘App\Http\Middleware\AdminMiddleware’], function()
Route::get(‘list-user’, ‘AdminController@listAllUsers’)->name(‘list-user’);

Route::group([‘middleware’ => ‘App\Http\Middleware\TeacherMiddleware’], function()
Route::get(‘list-student’, ‘TeacherController@listAllStudents’)->name(‘list-student’);

Route::group([‘middleware’ => ‘App\Http\Middleware\StudentMiddleware’], function()
Route::get(‘list-teacher’, ‘StudentController@listAllTeachers’)->name(‘list-teacher’);

7. I hope you are able to understand the above routing.

8. Next create the functions in respective controller. And also some modification is needed in Middleware say for example ill show the AdminMiddleware code below.

Image for post
Image for post

9. Create respective view files too.

10. Finally run the application, Login as student and try to access teachers url or admin url surely you will be able to see a page where it will tell that its restricted.

For the existing application find the github link below

Thanks, And sorry for my grammatical mistake and if the above tutorial is not good or not a good practice please correct me.

Thanks once again

Welcome to a place where words matter. On Medium, smart voices and original ideas take center stage - with no ads in sight. Watch
Follow all the topics you care about, and we’ll deliver the best stories for you to your homepage and inbox. Explore
Get unlimited access to the best stories on Medium — and support writers while you’re at it. Just $5/month. Upgrade

Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store