মিডলওয়্যার
মিডলওয়্যার লারাভেলের খুবই গুরুত্বপূর্ণ ও মজার একটি ফিচার । সহজ কথায় বলতে গেলে এটি একটি ফিল্টার মেকানিজম । যেমনঃ লা রাভেলের (ইউজার অথেনটিকেশন )।
মিডলওয়্যার কি তা তার নামের মধ্যেই আছে । মিডলওয়্যার রিকুয়েস্ট ও রেস্পন্সের মধ্যে সম্পর্ক স্থাপনকারী । ইউজার এর HTTP রিকুয়েস্ট ফিল্টার করে রিকুয়েস্টের পরে রেস্পন্স কি হবে তা মিডলওয়্যারে লেখা থাকে।
১. যেকোনো রকমের ইউজার অথেনটিকেশন ।
২. রাউটের মাধ্যমে আসা কোন API KEY হ্যান্ডেল করতে ।
৩. আপনার অ্যাপের জন্য এক্সেস মডিফায়ার তৈরি করতে (যেমনঃ ইউজার গেস্ট হলে কি দেখবে অথবা ইউজার অ্যাডমিন হলে কোন পেজ দেখাবে) ।
এতক্ষণে আশা করছি বুঝেই গেছেন মিডলওয়্যার এর গুরুত্ব । আসুন এবার মিডলওয়্যার বানিয়েই ফেলি।
Artisan এর মাধ্যমে লারাভেলে মিডলওয়্যার তৈরি করা সত্যিই পান্তাভাত (ইলিশ মাছ ছাড়া :p) Terminal ওপেন করুন এবং লিখুনঃ
php artisan make:middleware <middleware Name>
আমরা একটা মিডলওয়্যার নাহয় বানিয়েই ফেললাম। কিন্তু দেখেন এখন যে যুগ আসছে সবাইকেই ভেরিফাই করা লাগে !! তাহলে মিডলওয়্যারকে কেন নয় ??
চলুন দেখে নেই কিভাবে মিডলওয়্যার ভেরিফাই করা যায় ।
আপনি যদি আপনার মিডলওয়্যারটিকে সব রিকুয়েস্টের ক্ষেত্রেই একটিভ দেখতে চান তাহলেঃ
app/Http/kernel.php
এই ফাইলটি ওপেন করুন। এবং $middleware অ্যারেতে এভাবে অ্যা ড করুনঃprotected $middleware = [
...
\App\Http\Middleware\<middleware Name>:: class
]
এখন আপনি যদি মিডলওয়্যার ইউজারকে আপনার অ্যাপের নির্দিষ্ট কোন লিঙ্কে যাওয়ার সময় চেক করতে চান তাহলে মিডলওয়্যারটিকে রাউটের সাথে বেধে দিতে পারেন। যেমনঃ
Route::get (‘welcome’, ‘[email protected]_info’);
এখানে লক্ষ করুন ইউজার
<appURL>/welcome
লিখলে রাউট তাকে WelcomeController
এর profile_info
function এ নিয়ে যাবে।এখন আপনার ভাবনায় আসলো যে ...না এভাবে কোন ইউজার এসে প্রফাইল ইনফো নিয়ে জেতে পারবেন না। তাকে আগে দেখাতে হবে যে সে আসলেই আমার ইউজার । আপনার এই সমস্যার সমাধান নিয়েই হাজির মিডলওয়্যার!!
আপনি ইচ্ছা করলেই রাউটএর সাথে বেধে দিতে পারেন আপনার মিডলওয়্যারকে ঠিক আমি জেভাবে লিখলাম সেভাবে। ধরে নেই আপনার একটি auth মিডলওয়্যার আসে যেটা আপনার অ্যাপ ইউজার কিনা চেক করে। তাহলে লিখে ফেলুন এভাবেঃ
Route::get('welcome', '[email protected]_info')->middleware('Auth');
আবার ইচ্ছা করলে একাধিক মিডলওয়্যার ও ব্যবহার করতে পারেন এভাবেঃ
Route::get('welcome', '[email protected]_info')->middleware('Auth', 'admin');
লারাভেল আপনার কাজকে সহজ করার জন্য অতিমানবীয় আইডিয়া এনেছে এখানে। আপনি ভাবছেন আপনার অ্যাপে ওয়েব ও এপিআই রাউট দুইভাবে ইউজারকে ডাটা দিবেন। কিন্তু এত নিখুত ভাব ে কত মিডলওয়্যার লিখা যায় ?? এই সমস্যা সমাধান এর জন্য লারাভেল এনেছে গ্রুপ মিডলওয়্যার ।
app/Http/kernel.php
এই ফাইলে দেখবেন এভাবে লেখা আছে ।protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
'api' => [
'throttle:60,1',
'auth:api',
],
];
এই দুই অ্যারেতে আপনার ইচ্ছানুযায়ী মিডলওয়্যার অ্যাড করে দিতে পারেন ।
আমরা ইচ্ছা করলে মিডলওয়্যারে প্যারামিটার পাস করতে পারি। ধ রি আমাদের মিডলওয়্যারটি ইউজারএর রোল চেক করবে। তো মিডলওয়্যার ফাঙ্কশনে আমরা Closure প্যারামিটার এর মধ্যে দিয়ে $request পাস করতে পারি। যেমনঃ
public function handle($request, Closure $next, $role)
{
if (! $request->user()->hasRole($role)) {
// Redirect...
}
return $next($request);
}
এখন আমরা রাউটে মিডলওয়্যার অ্যাড করে দিব ।
Route::post('post/{id}', ['middleware' => 'role:editor', function ($id) {
//
}]);
এখন আপনি যদি চান মিডলওয়্যার আগে রান করবে এবং তারপর ইউজারকে রেসপন্স পাঠাবে । তাহলে আমরা এভাবে লিখতে পারিঃ
public function handle($request, Closure $next)
{
$response = $next($request);
/**
* Perform actions here
*/
return $response;
}
এখানে মোটামোটি মিডলওয়্যার নিয়ে ডিটেইলস আলোচনা করা হয়েছে । আপনি আরও জানতে চাইলে ভিজিট করুন লারাভেলের অফিসিয়াল পেইজে ।
Last modified 4yr ago