命令行创建中间件类文件示例
// app\middleware\authphp think make:middleware auth// app\middleware\admin\authphp think makbaby sister 歌词e:middleware admin/auth// app\admin\middleware\authphp think make:middleware admin@auth// pp\admin\middleware\login\authphp think make:mi有丝分裂ddleware admin@login/auth
本文使用的是
php think make:middleware admin@auth
创建中间件类文件后,就可以根据应用场景去注册中间件了
注册中间件分为四种类型: 全局中间件、应用中间件、路由中间件、控制器中间件
本文以最常见的场景为例: 将应用中间件作为登录流拦截器, 来说明前置中间件和后置中间件的区别
一个中间件是前置中间件还是后置中间件,看的是中间件执行代码在请求之前执行还是请求之后执行
请求指的是 $next($request)
,中间件执行代码在请求之前执行称为前置中间件,在请求美宝莲小灯管之后执行称为后置中间件
前置中间件: 中间件执行代码在 $next($request)
前面执行,如下图所示
后置中间件: 中间件执行代码在 $next($request)
后面执行,如下图所示
区别一: 在前置中间件中使用 $request->controller()
获取不到访问的控制器名,而在后置中间件中则可以正常获取到
在前置中间件打印 $request
发现是获取不到访问的控制器和方法名
在后置中间件打印 $request美术学类
可以获取到访问的控制器和方法名
区别二: 前置中间件没有执行控制器中的代码,而后置中间件则执行了
后置中间件存在的问题: 虽然能拦截,但是控制器中的代码已经执行了,因为调用 $next($request)
, 相当于执行控制器方法
如下图所示,在控制器方法中往文件中写入了一条数据,使用后置中间件时即使被拦截也会执行文件写入,所以使用后置中间拦截其实没有意义的,我们应该使用前置中间件进行拦截
后置中间件、控制器方法如下图所示
查看网页源代码,页面上输出的值如下所示
middleware start
业务逻辑
middleware ing
方法返回值
而不是
middleware start
middleware ing
业务逻辑
方法返回值
public function handle($request, \closure $next){ $respon = $next($request); $nocheck = ['login']; // 不做登陆校验的控制器 $controller = par_name($request->controller()); if (!ssion('?admin') && !in_array($controller, $nocheck)) { return redirect(url('admin/login')); } return $respon;}
在前置中间件中无法使用 $request->controller()
获取控制器名,但可以使用 $request->pathinfo()
获取当前路由地址
public function handle($request, \closure 什么是护理$next){ if (empty(ssion('admin')) && !preg_match('/login/', $request->pathinfo())) { return redirect((string)url('login/index')); } return $next($request);}
到此这篇关于thinkphp6.0前置、后置中间件区别的文章就介绍到这了,更多相关thinkphp6.0前置后置中间件内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 13:00:49,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/8f8f6f65c0e39527ed63a49de7af4fe4.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:ThinkPHP6.0前置、后置中间件区别.doc
本文 PDF 下载地址:ThinkPHP6.0前置、后置中间件区别.pdf
留言与评论(共有 0 条评论) |