1. 創建中間件
命令行創建中間件類文件示例
// appmiddlewareAuth php think make:middleware Auth // appmiddlewareadminAuth php think make:middleware admin/Auth // appadminmiddlewareAuth php think make:middleware admin@Auth // ppadminmiddlewareloginAuth php think make:middleware admin@login/Auth
本文使用的是
php think make:middleware admin@Auth
2. 注冊中間件
創建中間件類文件后,就可以根據應用場景去注冊中間件了
注冊中間件分為四種類型: 全局中間件、應用中間件、路由中間件、控制器中間件
本文以最常見的場景為例: 將應用中間件作為登錄流攔截器, 來說明前置中間件和后置中間件的區別
3. 前置、后置中間件
一個中間件是前置中間件還是后置中間件,看的是中間件執行代碼在請求之前執行還是請求之后執行
請求指的是 $next($request)
,中間件執行代碼在請求之前執行稱為前置中間件,在請求之后執行稱為后置中間件
前置中間件: 中間件執行代碼在 $next($request)
前面執行,如下圖所示
后置中間件: 中間件執行代碼在 $next($request)
后面執行,如下圖所示
4. 前置、后置中間件的區別
區別一: 在前置中間件中使用 $request->controller()
獲取不到訪問的控制器名,而在后置中間件中則可以正常獲取到
在前置中間件打印 $request
發現是獲取不到訪問的控制器和方法名
在后置中間件打印 $request
可以獲取到訪問的控制器和方法名
區別二: 前置中間件沒有執行控制器中的代碼,而后置中間件則執行了
后置中間件存在的問題: 雖然能攔截,但是控制器中的代碼已經執行了,因為調用 $next($request)
, 相當于執行控制器方法
如下圖所示,在控制器方法中往文件中寫入了一條數據,使用后置中間件時即使被攔截也會執行文件寫入,所以使用后置中間攔截其實沒有意義的,我們應該使用前置中間件進行攔截
后置中間件、控制器方法如下圖所示
查看網頁源代碼,頁面上輸出的值如下所示
middleware start
業務邏輯
middleware ing
方法返回值
而不是
middleware start
middleware ing
業務邏輯
方法返回值
5. 后置中間件登錄攔截器(不推薦)
public function handle($request, Closure $next) { $response = $next($request); $noCheck = ["login"]; // 不做登陸校驗的控制器 $controller = parse_name($request->controller()); if (!session("?admin") && !in_array($controller, $noCheck)) { return redirect(url("admin/login")); } return $response; }
6. 前置中間件登錄攔截器(推薦使用)
在前置中間件中無法使用 $request->controller()
獲取控制器名,但可以使用 $request->pathinfo()
獲取當前路由地址
public function handle($request, Closure $next) { if (empty(session("admin")) && !preg_match("/login/", $request->pathinfo())) { return redirect((string)url("login/index")); } return $next($request); }
到此這篇關于ThinkPHP6.0前置、后置中間件區別的文章就介紹到這了,更多相關ThinkPHP6.0前置后置中間件內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/qq_40994734/article/details/121734436