در فریمورک قدرتمند لاراول، مفهومی حیاتی به نام Middleware چیست وجود دارد که نقش نگهبان میان کاربر و منطق اصلی برنامه را ایفا میکند. میدلور همانند لایهای هوشمند عمل میکند که میتواند درخواستهای ورودی را قبل از رسیدن به کنترلر بررسی و پردازش کند. این ویژگی به توسعهدهندگان امکان میدهد تا کنترل دقیقی بر فیلتر کردن درخواست HTTP داشته باشند؛ برای مثال، بررسی احراز هویت کاربر یا جلوگیری از دسترسیهای غیرمجاز.
در مسیر آموزش لاراول، درک صحیح از Middleware یکی از گامهای کلیدی است. با استفاده از این ابزار، میتوان عملیاتهایی مانند ثبت لاگ، بررسی توکن امنیتی یا حتی تغییر محتوای پاسخ را انجام داد. این قابلیت انعطافپذیر باعث شده است تا فریمورک PHP لاراول، به یکی از کاملترین و ایمنترین گزینهها برای توسعه نرمافزارهای مدرن تبدیل شود.
میدلور در لاراول چیست؟ درک مفهوم و چرخه حیات درخواست
درک مفهوم Middleware در لاراول، یکی از مهمترین گامها برای فهم عمیق ساختار درونی این فریمورک قدرتمند است. میدلور در حقیقت لایهای میانی بین کاربر و منطق اصلی برنامه است که وظیفه دارد جریان داده را کنترل، بررسی و فیلتر کند. هر زمان که کاربری درخواستی به سرور ارسال میکند، این درخواست پیش از رسیدن به کنترلر، از چندین Middleware عبور میکند تا صحت و مجوز آن بررسی شود.
برای درک بهتر، باید به چرخه حیات درخواست در لاراول یا همان Request Lifecycle توجه کرد. هنگامی که یک ریکوئست وارد سیستم میشود، ابتدا از طریق فایل public/index.php وارد میگردد و سپس وارد لایههای مختلف از جمله Kernel، Service Providers و در نهایت میدلورها میشود. هر Middleware میتواند قبل از رسیدن به کنترلر یا پس از بازگشت پاسخ، عملیات خاصی مانند فیلتر کردن ریکوئست، بررسی توکنهای امنیتی یا اعمال محدودیتهای دسترسی را انجام دهد.
این ساختار منظم باعث میشود که معماری لاراول بسیار ماژولار و قابل گسترش باشد. توسعهدهندگان میتوانند میدلورهای سفارشی برای وظایف خاصی مانند احراز هویت، ثبت لاگ یا فشردهسازی پاسخها ایجاد کنند. بهعبارت دیگر، میدلورها نهتنها ابزار امنیتی قدرتمند هستند بلکه پلی انعطافپذیر میان ورودی و خروجی برنامه محسوب میشوند.
در نتیجه، فهم درست از مفهوم Middleware و نقش آن در چرخه حیات درخواست در لاراول، کلید اصلی ساخت برنامههای تمیز، امن و قابل نگهداری است. این مکانیزم زیربنایی، کنترل کامل بر رفتار هر ریکوئست را فراهم میکند و قدرت واقعی لاراول را در طراحی سیستمهای پیچیده آشکار میسازد.
چگونه اولین میدلور خود را در لاراول بسازیم؟
یکی از بخشهای جذاب و کاربردی در لاراول، امکان ساخت میدلور در لاراول است. میدلورها به شما اجازه میدهند تا منطق خاصی را قبل یا بعد از پردازش درخواستها اعمال کنید. برای مثال، میتوانید بررسی کنید که آیا کاربر وارد سیستم شده است یا خیر، یا حتی قبل از ارسال پاسخ، دادهها را تغییر دهید.
فرآیند ایجاد یک میدلور بسیار ساده است. تنها کافی است در ترمینال پروژه، دستور زیر را اجرا کنید:
php artisan make:middleware CheckUserStatus
این دستور همان دستور php artisan make:middleware است که یک فایل جدید در مسیر app/Http/Middleware ایجاد میکند. فایل ساختهشده شامل یک کلاس میدلور است که هسته اصلی آن، متدی به نام متد handle در میدلور میباشد. این متد همان نقطهای است که منطق شما در آن اجرا میشود.
بهطور معمول، ساختار متد handle به شکل زیر است:
public function handle($request, Closure $next)
{
if (!auth()->check()) {
return redirect('/login');
}
return $next($request);
}
در این مثال، اگر کاربر وارد سیستم نشده باشد، به صفحه ورود هدایت میشود. در غیر این صورت، درخواست به مرحله بعدی ارسال میشود. این الگو نشان میدهد که چگونه میتوانید با ایجاد میدلور سفارشی، مسیر جریان داده را کنترل کنید.
پس از ایجاد میدلور، باید آن را در فایل app/Http/Kernel.php ثبت کنید تا لاراول بتواند آن را شناسایی و اجرا کند. این ثبت میتواند در بخش routeMiddleware انجام شود، تا در مسیرهای خاصی از آن استفاده کنید.
در نهایت، کلاس میدلور بهعنوان لایهای میانی، قدرتی عظیم در مدیریت منطق امنیتی، فیلترینگ دادهها و بهینهسازی عملکرد به شما میدهد. با تسلط بر ساخت و استفاده از میدلورها، میتوانید برنامهای انعطافپذیر، تمیز و حرفهای خلق کنید که کاملاً منطبق بر نیازهای پروژه شما باشد.
ثبت و فعالسازی میدلور در لاراول
پس از ساخت میدلور در لاراول، گام بعدی، ثبت میدلور در لاراول است تا فریمورک بتواند آن را شناسایی و در مسیر چرخه پردازش درخواست (Request Lifecycle) اجرا کند. برخلاف کنترلرها یا مدلها، لاراول بهصورت خودکار از وجود میدلورهای جدید مطلع نمیشود. بنابراین، شما باید آن را در فایل مهمی به نام app/Http/Kernel.php ثبت کنید. این فایل همان جایی است که ترتیب اجرای میدلورها، گروهبندی آنها، و ارتباطشان با روتها مشخص میشود.
سه روش اصلی برای فعالسازی میدلورها وجود دارد:
-
ثبت سراسری (Global Middleware) برای تمام درخواستها.
-
ثبت در گروهها (Middleware Groups) برای مجموعهای از مسیرها.
-
ثبت اختصاصی (Route Middleware) برای یک یا چند مسیر خاص.
در ادامه، هر یک از این روشها را با جزئیات بررسی میکنیم.
ثبت میدلور به صورت سراسری (Global Middleware)
Global Middlewareها بهصورت خودکار روی همهی درخواستهای HTTP اجرا میشوند. این نوع از میدلورها مناسب زمانی هستند که بخواهید منطق خاصی را همیشه و در تمام مسیرها اعمال کنید، مانند:
-
ثبت گزارش (Logging) از تمام درخواستها
-
بررسی وضعیت سرور یا حالت نگهداری (Maintenance Mode)
-
افزودن هدرهای امنیتی یا تنظیمات CORS
برای فعالسازی، کافی است کلاس میدلور خود را در آرایهی $middleware در فایل Kernel.php ثبت کنید:
protected $middleware = [
\App\Http\Middleware\CheckUserStatus::class,
\App\Http\Middleware\LogRequests::class,
];
با این کار، هر درخواستی که وارد برنامه میشود، ابتدا از این لایهها عبور میکند، سپس به گروهها و در نهایت کنترلر میرسد. این ساختار کمک میکند منطقهای عمومی در کل اپلیکیشن بهصورت منسجم اجرا شوند.
ثبت میدلور برای گروههای روت (Middleware Groups)
لاراول برای راحتی کار توسعهدهندگان، مفهومی به نام Middleware Groups را معرفی کرده است. این گروهها به شما اجازه میدهند چندین میدلور را با هم ترکیب کرده و در یک مجموعهی واحد به کار ببرید. دو گروه پیشفرض در لاراول وجود دارد: web و api.
-
گروه web برای روتهایی استفاده میشود که به مرورگر و سشنها (Session) نیاز دارند.
-
گروه api برای مسیرهایی است که JSON برمیگردانند و معمولاً Stateless هستند.
در فایل Kernel.php، میتوانید میدلور خود را به یکی از این گروهها اضافه کنید:
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Session\Middleware\StartSession::class,
\App\Http\Middleware\CheckUserStatus::class, // میدلور جدید شما
],
'api' => [
'throttle:api',
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
];
هر مسیری که در فایل web.php تعریف شود، بهصورت خودکار از میدلورهای موجود در گروه web عبور میکند. این ساختار به شما کمک میکند میدلورها را به شکلی منطقی و سازمانیافته مدیریت کنید.
اختصاص میدلور به یک روت خاص (Route Middleware)
گاهی لازم است میدلور شما فقط برای چند مسیر خاص اجرا شود نه برای کل برنامه. پس باید در لایه Routing لاراول این تغییرات اعمال شود. در این حالت از Route Middleware استفاده میکنیم. برای این منظور، باید میدلور خود را در آرایهی $routeMiddleware در فایل Kernel.php ثبت کنید و برای آن یک نام مستعار (Alias) تعیین نمایید:
protected $routeMiddleware = [
'auth' => \App\Http\Middleware\Authenticate::class,
'check.user' => \App\Http\Middleware\CheckUserStatus::class,
];
اکنون میتوانید از آن نام مستعار در تعریف روتها استفاده کنید:
Route::get('/dashboard', [DashboardController::class, 'index'])
->middleware('check.user');
همچنین میتوانید چند میدلور را بهصورت همزمان برای یک روت تعریف کنید:
Route::post('/profile', [ProfileController::class, 'update'])
->middleware(['auth', 'check.user']);
این روش انعطافپذیری بالایی فراهم میکند و به شما اجازه میدهد کنترل دقیقی بر رفتار هر مسیر داشته باشید.
نکته حرفهای: ترکیب چند میدلور در پروژههای بزرگ
در پروژههای بزرگ، گاهی لازم است یک میدلور فقط برای بخشی از مسیرها اجرا شود، اما در چندین بخش مختلف تکرار شود. در این حالت، میتوانید یک گروه جدید در Kernel.php ایجاد کرده و آن را برای مسیرهای خاص فراخوانی کنید.
protected $middlewareGroups = [
'admin' => [
'auth',
'check.user',
'verified',
],
];
سپس در فایل web.php بهسادگی آن را اعمال کنید:
Route::middleware(['admin'])->group(function () {
Route::get('/admin/dashboard', [AdminController::class, 'index']);
});
به این ترتیب، تمام مسیرهای داخل این گروه از مجموعهای از میدلورها عبور میکنند و کد شما تمیز و سازمانیافته باقی میماند.
تکنیکهای پیشرفته: ارسال پارامتر به میدلور و میدلورهای Terminable

قدرت واقعی سیستم Middleware در لاراول زمانی آشکار میشود که از قابلیتهای پیشرفتهی آن استفاده کنیم. در بسیاری از پروژههای واقعی، نیاز داریم رفتار میدلور را بسته به شرایط مختلف تغییر دهیم یا عملیاتی را پس از ارسال پاسخ به کاربر انجام دهیم. در این بخش، با دو ویژگی کلیدی آشنا میشویم: ارسال پارامتر در میدلور لاراول و استفاده از Terminable Middlewareها برای پردازشهای پس از پاسخ.
ارسال پارامتر به میدلور (Middleware Parameters)
گاهی یک میدلور نیاز دارد برای سناریوهای متفاوت، رفتار متفاوتی از خود نشان دهد. در چنین مواردی میتوان از Middleware Parameters استفاده کرد. این قابلیت باعث میشود میدلور شما بهصورت میدلور داینامیک عمل کند و بسته به پارامترهای ورودی تصمیم بگیرد.
فرض کنید میدلوری با نام CheckRole دارید که باید بررسی کند آیا کاربر نقش خاصی دارد یا خیر. در فایل Kernel.php آن را با نام مستعار ثبت میکنید:
protected $routeMiddleware = [
'role' => \App\Http\Middleware\CheckRole::class,
];
سپس در مسیر خود، پارامتر نقش را ارسال میکنید:
Route::get('/admin', function () {
// ...
})->middleware('role:admin');
در داخل کلاس میدلور، متد handle پارامتر را به شکل زیر دریافت میکند:
public function handle($request, Closure $next, $role)
{
if (auth()->user()->role !== $role) {
abort(403);
}
return $next($request);
}
به این ترتیب، میتوانید از یک میدلور برای نقشهای مختلف مانند "admin"، "editor" یا "author" استفاده کنید، بدون نیاز به ساخت چندین کلاس مشابه.
میدلورهای قابل خاتمه (Terminable Middleware)
نوع خاصی از میدلورها با نام Terminable Middleware وجود دارد که پس از ارسال پاسخ به مرورگر همچنان اجرا میشوند. این ویژگی زمانی مفید است که بخواهید عملیاتی انجام دهید که نباید باعث تأخیر در پاسخ کاربر شود؛ مانند ثبت گزارشهای نهایی، بهروزرسانی وضعیت درخواستها یا ارسال نوتیفیکیشن.
برای ایجاد چنین میدلوری، کافی است در کلاس میدلور خود متد terminate را اضافه کنید:
public function terminate($request, $response)
{
Log::info('Request completed for user: ' . auth()->id());
}
زمانی که درخواست بهطور کامل پردازش شد، لاراول بهصورت خودکار این متد terminate را فراخوانی میکند.
استفاده از این دو قابلیت، به توسعهدهندگان اجازه میدهد میدلورهایی هوشمند، سریع و قابلانعطاف طراحی کنند. ترکیب Middleware Parameters و Terminable Middleware میتواند کنترل کامل بر جریان داده و عملیات پسزمینه را در اختیار شما قرار دهد و معماری پروژهی شما را به سطحی حرفهایتر ارتقا دهد.
کاربردهای عملی و بهترین الگوهای استفاده از میدلور در لاراول
تا اینجا با مفاهیم پایه و نحوهی ساخت و ثبت میدلورها آشنا شدیم. حال زمان آن رسیده است تا این دانش را در پروژههای واقعی بهکار بگیریم. در این بخش، با مجموعهای از مثالهای کاربردی آشنا میشویم که نشان میدهند چگونه میدلورها میتوانند منجر به افزایش امنیت در لاراول، ساختارمند شدن کد و بهبود عملکرد سیستم شوند.
میدلور برای احراز هویت (Authentication)
یکی از پرکاربردترین نمونهها، میدلور احراز هویت است که با بررسی وضعیت ورود کاربر، مانع دسترسی افراد غیرمجاز میشود. لاراول بهصورت پیشفرض دارای میدلور auth است که به شکل زیر استفاده میشود:
Route::get('/dashboard', [DashboardController::class, 'index'])
->middleware('auth');
این میدلور بررسی میکند که آیا کاربر وارد سیستم شده است یا خیر. اگر کاربر لاگین نکرده باشد، او را به صفحهی ورود هدایت میکند.
میدلور برای کنترل سطح دسترسی (Authorization)
گاهی کاربران وارد سیستم شدهاند اما مجاز به انجام همهی عملیاتها نیستند. در چنین مواردی، کنترل سطح دسترسی با استفاده از یک میدلور سفارشی انجام میشود. برای مثال:
public function handle($request, Closure $next, $role)
{
if ($request->user()->role !== $role) {
abort(403, 'Access Denied');
}
return $next($request);
}
با این روش میتوانید مسیرهایی را فقط برای نقشهایی مانند "admin" یا "editor" در دسترس قرار دهید.
میدلور برای جلوگیری از حملات CSRF

حفاظت در برابر حملات CSRF از دیگر موارد حیاتی امنیت در پروژههای وب است. لاراول بهصورت پیشفرض دارای میدلور VerifyCsrfToken است که توکن امنیتی را در فرمها بررسی میکند. این میدلور تضمین میکند که هیچ درخواست جعلی از منبع خارجی پذیرفته نشود:
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\VerifyCsrfToken::class,
],
];
میدلور برای لاگ کردن درخواستها (Request Logging)
در پروژههای بزرگ، ثبت جزئیات هر درخواست میتواند در تحلیل عملکرد و امنیت مفید باشد. یک مثال میدلور لاراول برای لاگ کردن:
public function handle($request, Closure $next)
{
Log::info('Request URL: ' . $request->fullUrl());
return $next($request);
}
این میدلور هر درخواست را در فایل لاگ ذخیره میکند و برای مانیتورینگ رفتار کاربران کاربردی است.
میدلور برای تنظیم هدرهای HTTP
در بسیاری از پروژهها نیاز دارید تا با افزودن هدرهای امنیتی یا تنظیم CORS، ارتباط امن بین کلاینت و سرور برقرار کنید. مثال:
public function handle($request, Closure $next)
{
$response = $next($request);
$response->headers->set('X-Frame-Options', 'DENY');
$response->headers->set('Access-Control-Allow-Origin', '*');
return $response;
}
این کد مانع از اجرای محتوای سایت در iframeهای خارجی میشود و همزمان اجازهی ارتباط امن API را میدهد.
در مجموع، میدلورها در لاراول ابزاری قدرتمند برای کنترل جریان داده، افزایش امنیت، و سادهسازی منطق اپلیکیشن هستند. استفادهی صحیح از آنها به شما کمک میکند تا کدهایی تمیزتر، سریعتر و حرفهایتر بنویسید.
تغییرات میدلور در لاراول ۱۱: رویکرد مدرن
در نسخه جدید لاراول ۱۱، ساختار مدیریت میدلورها دستخوش تغییراتی بنیادین و هوشمندانه شده است. فریمورک با حذف فایل سنتی Kernel.php و انتقال تنظیمات به فایل bootstrap/app.php، فرآیند تعریف و ثبت میدلورها را سادهتر و یکپارچهتر کرده است. این تغییر باعث شده مدیریت چرخهی درخواستها شفافتر، سریعتر و سازگارتر با معماری ماژولار لاراول شود.
در ساختار جدید، میتوانید با استفاده از متد withMiddleware، میدلورهای خود را بهصورت مستقیم در فایل app.php تعریف کنید. برای مثال:
->withMiddleware(function (Middleware $middleware) {
$middleware->web(append: [
\App\Http\Middleware\CheckUserStatus::class,
]);
});
این رویکرد جدید نهتنها نیاز به ویرایش چند فایل را حذف میکند، بلکه هماهنگی بهتری با سیستم بوتاسترپ لاراول دارد. بهطور خلاصه، تغییرات لاراول ۱۱ در حوزهی میدلورها، گامی در جهت ساختار جدید لاراول و توسعهی کدهای تمیز، ماژولار و قابلنگهداریتر محسوب میشود.
جمعبندی نهایی: میدلور، ستون امنیت و کنترل در لاراول
میدلورها در لاراول یکی از بنیادیترین اجزای فریمورک محسوب میشوند که نقش کلیدی در امنیت، کنترل جریان داده و بهینهسازی عملکرد اپلیکیشن دارند. که معماری mvc لاراول را امن میکند. آنها مانند لایهای هوشمند میان کاربر و منطق اصلی برنامه عمل میکنند و امکان بررسی، فیلتر و پردازش درخواستها را قبل یا بعد از رسیدن به کنترلر فراهم میسازند.
با درک درست از ساختار و چرخهی حیات درخواستها، میتوان از Middleware برای پیادهسازی وظایف مهمی مانند احراز هویت، بررسی سطح دسترسی، ثبت لاگها، جلوگیری از حملات امنیتی و تنظیم هدرهای HTTP استفاده کرد. این انعطافپذیری باعث میشود برنامههای لاراولی هم ایمنتر و هم قابل نگهداریتر باشند.
در نسخهی جدید لاراول ۱۱، مدیریت میدلورها با حذف فایل Kernel.php و انتقال تنظیمات به فایل bootstrap/app.php سادهتر و مدرنتر شده است. این تغییر رویکردی تازه و هماهنگ با معماری ماژولار فریمورک ایجاد کرده که توسعهی پروژههای بزرگ را تسهیل میکند.
در نهایت، تسلط بر مفاهیم و تکنیکهای پیشرفتهی میدلور مانند ارسال پارامتر، Terminable Middleware و گروهبندی هوشمند، به شما قدرت طراحی اپلیکیشنهایی تمیز، سریع و مقیاسپذیر را میدهد. اگر هدف شما ساخت برنامهای حرفهای با کنترل دقیق بر هر درخواست است، میدلورها همان ابزار کلیدیاند که باید بهخوبی آنها را بشناسید.









نظر خود را بنویسید