There are three ways to apply middleware in Laravel: directly within a single route, routing group, or controller. First, you can use the ->middleware() method to specify middleware or middleware arrays for a single route, such as Route::get('/dashboard')->middleware('auth'); or ->middleware(['auth', 'admin']); Second, you can apply middleware to a routing group through Route::middleware([...])->group() so that all routes in the group inherit the middleware stack; Third, you can call $this->middleware() in the controller constructor to define controller-level middleware, and you can restrict application methods through ->only() or ->except(); in addition, you can create custom middleware through Artisan and register it in the Kernel for reuse.
In Laravel, applying middleware to routes is straightforward and flexible — you can do it directly on individual routes, groups of routes, or even within controllers.
What Middleware Does in Laravel
Middleware works like a filter for HTTP requests entering your app. It lets you check or modify the request before it reaches the route handler — things like authentication checks, logging, or CORS headers are common use cases.
Apply Middleware to a Single Route
If you want to apply middleware to just one specific route, you can do it inline when defining the route.
For example, if you have a route that should only be accessible by authenticated users:
Route::get('/dashboard', function () { // Your logic here })->middleware('auth');
You can also apply multiple middlewares by passing an array:
Route::get('/admin', function () { // Admin dashboard })->middleware(['auth', 'admin']);
This method is great when you need fine-grained control over which routes get which middleware.
Apply Middleware to a Group of Routes
Most apps have sections that share the same middleware — like admin pages needing an admin
middleware or API routes needing auth:sanctum
.
You can wrap those routes in a group:
Route::middleware(['auth', 'admin'])->prefix('admin')->group(function () { Route::get('/users', function () { /* ... */ }); Route::get('/settings', function () { /* ... */ }); });
This way, all routes inside the group inherit the middleware stack, and you don't have to repeat yourself.
Assign Middleware Inside a Controller
Sometimes it makes more sense to define middleware at the controller level instead of the route file.
In your controller's constructor, you can do this:
public function __construct() { $this->middleware('auth'); }
Or restrict middleware to certain methods:
$this->middleware('auth')->only('edit', 'update');
Or exclude certain methods:
$this->middleware('auth')->except('index');
This keeps things clean when a controller has several routes but only some need protection.
Custom Middleware: Create Your Own Logic
Laravel comes with built-in middleware like auth
and throttle
, but sometimes you need something custom — like checking user roles or permissions.
To create your own middleware:
php artisan make:middleware EnsureUserIsAdmin
Then in the generated file ( app/Http/Middleware/EnsureUserIsAdmin.php
), add your logic:
public function handle($request, $next) { if (! $request->user()->isAdmin()) { return redirect('home'); } return $next($request); }
Register it in app/Http/Kernel.php
under $routeMiddleware
:
'admin' => \App\Http\Middleware\EnsureUserIsAdmin::class,
Now you can use 'admin'
anywhere else in your routes or controllers.
So yes, applying middleware in Laravel isn't hard — it's just a matter of choosing where and how you apply it. Whether per-route, grouped, or controller-based, Laravel gives you options that scale well from small to large apps. And creating custom middleware is easy enough once you know where to register it.
The above is the detailed content of How do I apply middleware to routes in Laravel?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

InLaravel,policiesorganizeauthorizationlogicformodelactions.1.Policiesareclasseswithmethodslikeview,create,update,anddeletethatreturntrueorfalsebasedonuserpermissions.2.Toregisterapolicy,mapthemodeltoitspolicyinthe$policiesarrayofAuthServiceProvider.

Yes,youcaninstallLaravelonanyoperatingsystembyfollowingthesesteps:1.InstallPHPandrequiredextensionslikembstring,openssl,andxmlusingtoolslikeXAMPPonWindows,HomebrewonmacOS,oraptonLinux;2.InstallComposer,usinganinstalleronWindowsorterminalcommandsonmac

The main role of the controller in Laravel is to process HTTP requests and return responses to keep the code neat and maintainable. By concentrating the relevant request logic into a class, the controller makes the routing file simpler, such as putting user profile display, editing and deletion operations in different methods of UserController. The creation of a controller can be implemented through the Artisan command phpartisanmake:controllerUserController, while the resource controller is generated using the --resource option, covering methods for standard CRUD operations. Then you need to bind the controller in the route, such as Route::get('/user/{id

Laravel allows custom authentication views and logic by overriding the default stub and controller. 1. To customize the authentication view, use the command phpartisanvendor:publish-tag=laravel-auth to copy the default Blade template to the resources/views/auth directory and modify it, such as adding the "Terms of Service" check box. 2. To modify the authentication logic, you need to adjust the methods in RegisterController, LoginController and ResetPasswordController, such as updating the validator() method to verify the added field, or rewriting r

Laravelprovidesrobusttoolsforvalidatingformdata.1.Basicvalidationcanbedoneusingthevalidate()methodincontrollers,ensuringfieldsmeetcriterialikerequired,maxlength,oruniquevalues.2.Forcomplexscenarios,formrequestsencapsulatevalidationlogicintodedicatedc

Selectingonlyneededcolumnsimprovesperformancebyreducingresourceusage.1.Fetchingallcolumnsincreasesmemory,network,andprocessingoverhead.2.Unnecessarydataretrievalpreventseffectiveindexuse,raisesdiskI/O,andslowsqueryexecution.3.Tooptimize,identifyrequi

InLaravelBladetemplates,use{{{...}}}todisplayrawHTML.Bladeescapescontentwithin{{...}}usinghtmlspecialchars()topreventXSSattacks.However,triplebracesbypassescaping,renderingHTMLas-is.Thisshouldbeusedsparinglyandonlywithfullytrusteddata.Acceptablecases

TomockdependencieseffectivelyinLaravel,usedependencyinjectionforservices,shouldReceive()forfacades,andMockeryforcomplexcases.1.Forinjectedservices,use$this->instance()toreplacetherealclasswithamock.2.ForfacadeslikeMailorCache,useshouldReceive()tod
