本文實例講述了laravel框架中間件簡單使用方法。分享給大家供大家參考,具體如下:
laravel內(nèi)置了一個中間件來驗證用戶是否經(jīng)過認證,如果用戶沒有經(jīng)過認證,中間件會將用戶重定向到登錄頁面,否則如果用戶經(jīng)過認證,中間件就會允許請求繼續(xù)往前進入下一步操作。
當然,除了認證之外,中間件還可以被用來處理更多其它任務。比如:CORS 中間件可以用于為離開站點的響應添加合適的頭(跨域);日志中間件可以記錄所有進入站點的請求。
Laravel框架自帶了一些中間件,包括認證、CSRF 保護中間件等等。所有的中間件都位于 app/Http/Middleware目錄。
中間是請求前還是請求后執(zhí)行取決于中間件本身,以下中間件會在請求處理前執(zhí)行一些任務
?php
namespace App\Http\Middleware;
use Closure;
class TestMiddle
{
public function handle($request, Closure $next)
{
// 執(zhí)行動作
if(!$request->session()->has('huser')){
return redirect("login/index");
}
return $next($request);
}
}
而下面這個中間件則會在請求處理后執(zhí)行其任務:
?php
namespace App\Http\Middleware;
use Closure;
class TestMiddle
{
public function handle($request, Closure $next)
{
$response = $next($request);
// 執(zhí)行動作
if(!$request->session()->has('huser')){
return redirect("login/index");
}
return $response;
}
}
中間件可以自己在編輯器里面新建對應類生成,也可用命令生成
php artisan make:middleware TestMiddle
此時,laravel的app\Http\Middleware\目錄就會多一個TestMiddle.php的中間件文件
此時中間件還不能直接使用,必須把它注冊到我們的laravel中,如下
只需在 app/Http/Kernel.php 類(3個屬性,對應里面加入,我有時用路由的)
'TestMiddle' => \App\Http\Middleware\TestMiddle::class,
分配中間件到路由,下面介紹三種方式
Route::get('/',function(){
return redirect('home/index');
})->middleware('TestMiddle');
Route::group(['middleware' => ['TestMiddle']], function() {
Route::controller("db","DataBaseController");
});
Route::controller("home","HomeController",['middleware'=>'TestMiddle']);
更多關于Laravel相關內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。
您可能感興趣的文章:- Laravel中間件實現(xiàn)原理詳解
- Laravel框架實現(xiàn)利用中間件進行操作日志記錄功能
- Laravel的throttle中間件失效問題解決方法
- Laravel獲取當前請求的控制器和方法以及中間件的例子
- laravel框架中間件 except 和 only 的用法示例
- Laravel框架基于中間件實現(xiàn)禁止未登錄用戶訪問頁面功能示例
- 淺談Laravel中的三種中間件的作用
- Laravel5.1框架注冊中間件的三種場景詳解
- laravel利用中間件防止未登錄用戶直接訪問后臺的方法
- laravel利用中間件做防非法登錄和權限控制示例
- 基于Laravel 多個中間件的執(zhí)行順序詳解
- Laravel5.1 框架Middleware中間件基本用法實例分析