Spread the love

In this tutorial we will going to learn custom middleware in Laravel 8. Middleware are used to create a layer between request and response of the http request. it filters or create a logic before the request serve to the controller and also filter or modify the response. we can also use it to validate the user auth, JSON request to manipulate the request and response.

In this example we will execute a user check with status in not block by admin. if it’s blocked by admin then show the response accordingly.

Let’s begin with simple example and step by step process:

Before start i assume you well known to Laravel project creation step and creating controllers.

Step 1 : Create Middleware

First step is to create the middleware using the Laravel artisan command or manually, so open the terminal at project location and run below command

php artisan make:middleware CheckBlacklist

Above command will create a middleware at location app\Http\Controllers\Middleware or you can also create the same manually at same location without artisan command.

<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Http\Request;

class CheckBlacklist
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle(Request $request, Closure $next)
    {
        return $next($request);
    }
}

Step 2: Register new middleware in kernal

Now, go to app/http/kernel.php and register the new middleware if you want this to register for all the http request otherwise you can skip this step


use Illuminate\Foundation\Http\Kernel as HttpKernel;


class Kernel extends HttpKernel
{
    ....


    /**
     * The application's route middleware.
     *
     * These middleware may be assigned to groups or used individually.
     *
     * @var array
     */
    protected $routeMiddleware = [
        ....
        'checkBlacklist' => \App\Http\Middleware\CheckBlacklist::class,
    ];
}

Step 3: Implement the logic in middleware

We have created our custom middleware and defined in kernel, now it’s time e to implement the our core logic for check blacklisted user.

<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Http\Request;

class CheckBlacklist
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle(Request $request, Closure $next)
    {
        if (auth()->user()->is_blacklisted == 0) {
            return $next($request);
        }
        return response()->json('Your account is blacklisted by admin'); 
   }
}

Here, we added the simple logic to check is the user is blacklisted or not, if yes then show the response Your account is blacklisted by admin.

Step 4: Create the route and add middleware

It’s time to add our new middleware to the our route so we can validate the request.

<?php

use Illuminate\Support\Facades\Route;
use \App\Http\Controllers\PostController;
use App\Http\Middleware\CheckBlacklist;

/*
|--------------------------------------------------------------------------
| Web Routes
|--------------------------------------------------------------------------
|
| Here is where you can register web routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| contains the "web" middleware group. Now create something great!
|
*/

Route::get('/create-post',[PostController::class, 'create'])->middleware(CheckBlacklist::class);

//or to group

Route::middleware(CheckBlacklist::class)->namespace('\App\Http\Controllers\Api')->group(function(){

Route::get("edit-post",[PostController::class, 'edit']);
});

here, we assigned middleware to a single route as well to the group.

Step 5: Create controller and method

Now, it’s time to test our implementation and create a controller

<?php

 namespace App\Http\Controllers;

 use Illuminate\Http\Request;
 class PostController extends Controller
 {
     public function create()
     {
         response()->json('You are good to go');
     }
 }
?>

How to modify response in middleware in Laravel 8 ?

In the above steps we learn to filter and check the blacklist status of user, now we are going to modify our response.

<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Http\Request;

class CheckBlacklist
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle(Request $request, Closure $next)
    {
        if (auth()->user()->is_blacklisted == 0) {
            $response = $next($request); // this is response from controller 
            // change the response and send to browser
            $content = $response->getContent();

    // ... process widgets in $content

          return $response->setContent($content);
            
        }
        return response()->json('Your account is blacklisted by admin'); 
   }
}

here we added a extra variable $response which take the value of controller response

$response = $next($request);

Now, we can modify $response to send the browser.

Leave a Reply