ThinkPHP6.0前置、后置中间件区别

admin3年前PHP教程43
目录
1. 创建中间件2. 注册中间件3. 前置、后置中间件4. 前置、后置中间件的区别5. 后置中间件登录拦截器(不推荐)6. 前置中间件登录拦截器(推荐使用)

 

1. 创建中间件

命令行创建中间件类文件示例

// appmiddlewareAuthphp think make:middleware Auth// appmiddlewareadminAuthphp think make:middleware admin/Auth// appadminmiddlewareAuthphp think make:middleware admin@Auth// ppadminmiddlewareloginAuthphp 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前置后置中间件内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:blog.csdn/qq_40994734/article/details/121734436

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

香港多ip服务器有什么好处

当您需要在香港访问网络资源时,香港多IP服务器可以为您提供许多好处。以下是一些香港多IP服务器的好处:访问速度快:使用位于香港的服务器可以获得更快的访问速度,因为数据传输的距离更短,减少了延迟和网络拥...

深入浅出理解PHP原理之变量赋值

PHP的变量赋值这个标题估计很多人会不屑一顾,变量赋值?excuse me?我们学开发的第一课就会了好不好。但是,就是这样基础的东西,反而会让很多人蒙圈,比如,值和引用的关系。今天,我们就来具体讲讲。...

GPU显卡服务器从哪几方面来选择呢香港显卡服务器租用地址是多少

显卡服务器(GPUCloudComputing,简称GPU)是基于GPU应用的计算服务,具有实时高速的并行计算和浮点计算能力,一般适用于3D图形应用程序、视频解码、深度学习、科学计算等应用场景。用途是...

php之深入理解架构布局讲解

本文基于《php 内核剖析》与 《php7底层设计与源码实现》所记笔记。对php内核的深入理解有助于我们对php的整体认识,对于业务层初期发展我们可以只了解基本语言的逻辑就可以写出符合业务的代码,但是...

企业为什么要选择租用宁波高防服务器来防御ddos攻击

企业为什么要选择租用宁波高防服务器来防御ddos攻击?企业选择租用宁波高防服务器来防御DDoS攻击的原因有以下几点:高防服务器具有强大的防御能力:高防服务器可以通过多种方式,如流量清洗、黑白名单过滤、...

分析PHP的垃圾回收机制

如果用过C语言,那么申请内存的方式是malloc或者是calloc,然后你用完这个内存后,一定不要忘了用free函数去释放掉,这就是传说中手动垃圾回收,一般都是扫地神僧用这种方式。很多高层次语言中,你...