ThinkPHP前置、后置中间件是什么,有何差异
Admin 2022-08-04 群英技术资讯 619 次浏览
命令行创建中间件类文件示例
// app\middleware\Auth php think make:middleware Auth // app\middleware\admin\Auth php think make:middleware admin/Auth // app\admin\middleware\Auth php think make:middleware admin@Auth // pp\admin\middleware\login\Auth php think make:middleware 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) { $response = $next($request); $noCheck = ['login']; // 不做登陆校验的控制器 $controller = parse_name($request->controller()); if (!session('?admin') && !in_array($controller, $noCheck)) { return redirect(url('admin/login')); } return $response; }
在前置中间件中无法使用 $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); }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
php怎样实现文件分片上传?如果我们要上传的文件比较大,那么上传速度是比较慢的,而对文件分片上传的目的是为了实现文件更加迅速的上传。这篇文章就主要给大家分享PHP实现文件分片上传的方法及步骤,感兴趣的朋友可以参考。
今天小编就为大家分享一篇laravel 关联关系遍历数组的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
会话机制(Session)在PHP中用于保存并发访问中的一些数据。这使可以帮助创建更为人性化的程序,增加站点的吸引力。一个访问者访问你的web网站将被分配一个唯一的id...
这篇文章主要介绍了PHP常见加密函数用法,结合实例形式分析了crypt与md5函数进行加密操作相关使用技巧与注意事项,需要的朋友可以参考下
ThinkPHP5.1 已经出现很久了,最近有所接触,下面介绍一下常用的第三方验证码功能的使用,有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008