这篇文章给大家分享的是有关ThinkPHP6.0之中间件是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
ThinkPHP6.0中间件分为系统中间件和应用中间件,系统中间件为核心框架内置的中间件,应用中间件是在应用里面创建的中间件。
中间件的主要应用场景可以包括对HTTP请求的数据过滤,权限检测,请求拦截等行为,使用中间件能够让控制器的定义更加简单,很多额外的非核心业务流程的处理都可以交给中间件执行。
从中间件的使用范围来看,可以分为全局中间件,应用中间件,控制器中间件和路由中间件。
<强>全局中间件强>
全局中间件是在app \中间件。php中定义的中间件,默认没有启用任何中间件,但对支持的系统中间件做了注释,你只需要取消注释就可以使用相应的系统中间件,默认内容如下:
return ( ,,,//,全局请求缓存 ,,,//,& # 39;认为\中间件\ CheckRequestCache& # 39; ,,,//,多语言加载 ,,,//,& # 39;认为\中间件\ LoadLangPack& # 39; ,,,//,会话初始化 ,,,//,& # 39;认为\中间件\ SessionInit& # 39; ,,,//,页面跟踪调试 ,,,//,& # 39;认为\中间件\ TraceDebug& # 39; ];
系统的部分功能交给中间件进行统一管理,包括全局请求缓存,多语言的自动检测和加载,会话初始化和页面跟踪调试,也就是说,默认安装后的应用是不支持会话的,你必须全局开启会话初始化中间件后会话才能生效。对应于API用来说,本身就不需要会话功能支持。
你可以在全局中间件定义文件中添加你的应用中间件,但尽可能确保系统中间件的优先执行,中间件定义需要使用完整的类名,通过命令行指令可以快速创建一个应用中间件:
php think : middleware 测试
会自动生成一个应用程序、中间件、测试中间件类,内容如下:
& lt; php ? namespace app \中间件; class 测试 { ,,,public function 处理(请求,美元,\ Closure 下一美元) ,,,{ ,,,} }
也支持通过指定完整命名空间的方式创建中间件类
php think : middleware 应用中间件\ \ Hello
我们添加一个测试输出
& lt; php ? namespace app \中间件; class 测试 { ,,,public function 处理(请求,美元,\ Closure 下一美元) ,,,{ ,,,echo & # 39; Before Middleware
中间件处理方法的返回值必须是一个响应对象。
然后在全局中间件定义中添加
return ( 中间件\ app \ \测试::类, ];假设我们要访问的控制器方法为
& lt; php ? namespace app \控制器; class 指数 { ,,,public function hello () ,,,{ ,,,return & # 39;你好,ThinkPHP ! & lt; br/祝辞& # 39;; ,,,} }访问该操作方法的输出为
Before 中间件 你好,ThinkPHP ! After 中间件你可以看出中间件的执行过程,从执行流程上可以分为前置中间件和后置中间件,当然,一个中间件可能同时有前置和后置行为,上面的测试中间件就是如此。一美元($请求)之前的代码属于前置中间件范畴,之后的代码则属于后置中间件范畴。
<强>应用中间件强>
如果是多应用模式的话,应用中间件就是在app \应用名\中间件。php中定义的中间件,只会在该应用下有效,定义格式和全局中间件一致。
<>强路由中间件强>
路由中间件则表示仅在路由匹配之后才会执行某个中间件,在路由定义中使用中间件方法定义,例如:
路线::获得(& # 39;你好/:名字# 39;,& # 39;索引/你好# 39;) ,,,→中间件(中间件\ \ app \你好::类),可以给路由分组定义中间件
路线::集团(函数(){ 路线:get(& # 39;你好/:名字# 39;,& # 39;索引/你好# 39;);//? })→中间件(中间件\ \ app \你好::类),如果要执行多个中间件,可以使用
ThinkPHP6.0之中间件是什么