您现在的位置是:群英 > 开发技术 > 编程语言
Thinkphp6.0按中间件的使用范围划分有几类
Admin发表于 2022-09-24 17:13:18395 次浏览
这篇文章主要为大家详细介绍了Thinkphp6.0按中间件的使用范围划分有几类的内容,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望对大家学习或工作能有帮助,接下来就跟随小编一起来学习吧。

6.0中间件分为系统中间件和应用中间件,系统中间件为核心框架内置的中间件,应用中间件是在应用里面创建的中间件。

中间件的主要应用场景可以包括对HTTP请求的数据过滤、权限检测、请求拦截等行为,使用中间件能够让控制器的定义更加简单,很多额外的非核心业务流程的处理都可以交给中间件执行。

从中间件的使用范围来看,可以分为全局中间件、应用中间件、控制器中间件和路由中间件。

全局中间件

全局中间件是在app\middleware.php中定义的中间件,默认没有启用任何中间件,但对支持的系统中间件做了注释,你只需要取消注释就可以使用相应的系统中间件,默认内容如下:

return [
    // 全局请求缓存
    // 'think\middleware\CheckRequestCache',
    // 多语言加载
    // 'think\middleware\LoadLangPack',
    // Session初始化
    // 'think\middleware\SessionInit',
    // 页面Trace调试
    // 'think\middleware\TraceDebug',
];

系统的部分功能交给中间件进行统一管理,包括全局请求缓存、多语言的自动检测和加载、Session初始化和页面Trace调试,也就是说,默认安装后的应用是不支持Session的,你必须全局开启Session初始化中间件后Session才能生效。对于API应用来说,本身就不需要Session功能支持。

你可以在全局中间件定义文件中添加你的应用中间件,但尽可能确保系统中间件的优先执行,中间件定义需要使用完整的类名,通过命令行指令可以快速创建一个应用中间件:

php think make:middleware Test

会自动生成一个app\middleware\Test中间件类,内容如下:

<?php
 
namespace app\middleware;
 
class Test
{
    public function handle($request, \Closure $next)
    {
    }
}

也支持通过指定完整命名空间的方式创建中间件类

php think make:middleware app\middleware\Hello


我们添加一个测试输出

<?php
 
namespace app\middleware;
 
class Test
{
    public function handle($request, \Closure $next)
    {
     echo 'Before Middleware<br/>';
     $response = $next($request);
     echo 'After Middleware<br/>';
     return $response;
    }
}

中间件handle方法的返回值必须是一个Response对象。

然后在全局中间件定义中添加

return [
 \app\middleware\Test::class,
];

假设我们要访问的控制器方法为

<?php
 
namespace app\controller;
 
class Index
{
    public function hello()
    {
     return 'Hello,ThinkPHP!<br/>';
    }
}

访问该操作方法的输出为

Before Middleware
Hello,ThinkPHP!
After Middleware

你可以看出中间件的执行过程,从执行流程上可以分为前置中间件和后置中间件,当然,一个中间件可能同时有前置和后置行为,上面的Test中间件就是如此。 $next($request)之前的代码属于前置中间件范畴,之后的代码则属于后置中间件范畴。

应用中间件

如果是多应用模式的话,应用中间件就是在app\应用名\middleware.php中定义的中间件,只会在该应用下有效,定义格式和全局中间件一致。

路由中间件

路由中间件则表示仅在路由匹配之后才会执行某个中间件,在路由定义中使用middleware方法定义,例如:

Route::get('hello/:name','index/hello')
    ->middleware(\app\middleware\Hello::class);

可以给路由分组定义中间件

Route::group(function(){
 Route::get('hello/:name','index/hello');
 //...
})->middleware(\app\middleware\Hello::class);

如果要执行多个中间件,可以使用

Route::group(function(){
 Route::get('hello/:name','index/hello');
 //...
})->middleware([\app\middleware\Hello::class,\app\middleware\Check::class]);

对于经常要使用的中间件,我们可以定义一个别名,在config\middleware.php配置文件中,设置

return [
 'hello' => \app\middleware\Hello::class,
 'check' => \app\middleware\Check::class,
];

路由定义可以改为:

Route::group(function(){
 Route::get('hello/:name','index/hello');
 //...
})->middleware(['hello','check']);

支持给一组中间件定义别名

return [
 'test' => [\app\middleware\Hello::class,\app\middleware\Check::class],
];

路由定义可以改为

Route::group(function(){
 Route::get('hello/:name','index/hello');
 //...
})->middleware('test');

中间件支持传入一个参数,中间件定义如下

<?php
 
namespace app\middleware;
 
class Hello
{
    public function handle($request, \Closure $next, string $name = '')
    {
     echo 'Hello'. $name . '<br/>';
     return $next($request);
    }
}

可以在路由中间件的第二个参数传入name参数

Route::get('hello/:name','index/hello')
    ->middleware('hello', 'middleware');

除了支持参数外,你可以在中间件的handle方法中使用依赖注入。

控制器中间件

控制器中间件仅当访问某个控制器的时候生效

<?php
 
namespace app\controller;
 
class Hello
{
 protected $middleware = ['hello','check'];
 
    public function index()
    {
     return 'Hello,ThinkPHP!<br/>';
    }
}

由于前面已经定义了中间件别名,所以这里直接使用别名定义,否则你必须使用完整的命名空间定义。

默认情况下,控制器中定义的中间件访问控制器的任何操作方法都会执行,有时候并不希望所有的操作都需要执行中间件,有两种方式来定义控制器中间件的执行过滤。

<?php
 
namespace app\controller;
 
class Index
{
 protected $middleware = [
  'hello' => ['only'  => ['hello']],
  'check' => ['except'=> ['hello']],
 ];
 
    public function hello()
    {
     return 'Hello,ThinkPHP!<br/>';
    }
 
    public function check()
    {
     return 'this action require check!<br/>';
    }    
}

hello中间件仅在执行Index控制器的hello操作的时候才会执行,而check中间件除了hello方法外,都会执行,具体效果你可以实际测试下。

中间件传参

中间件和控制器之间传参的方式有很多,一个简单的方法是使用Request来进行传参。

<?php
 
namespace app\middleware;
 
class Hello
{
    public function handle($request, \Closure $next)
    {
        $request->hello = 'ThinkPHP';
        
        return $next($request);
    }
}

中间件向控制器传参必须在前置中间件完成,后置中间件向控制器的传参控制器无法接收。

然后在控制器的方法里面可以直接使用

public function index(Request $request)
{
 return $request->hello; // ThinkPHP
}



到此这篇关于“Thinkphp6.0按中间件的使用范围划分有几类”的文章就介绍到这了,感谢各位的阅读,更多相关Thinkphp6.0按中间件的使用范围划分有几类内容,欢迎关注群英网络资讯频道,小编将为大家输出更多高质量的实用文章!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

相关信息推荐
2022-01-27 21:01:09 
摘要:这篇文章给大家分享的是HTML中横向导航的实现。小编觉得挺实用的,因此分享给大家做个参考,文中的实现思路和方法介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
2022-06-01 17:37:38 
摘要:转换方法:1、利用foreach语句通过引用循环的方式来遍历数组,语法“foreach ($array as &$v){//循环体}”;2、在循环体中,用bin2hex()函数将数组元素转为16进制,语法“$v=bin2hex($v);”。
2021-11-20 17:45:42 
摘要:这篇文章我们来了解Django模板继承的相关内容,下文介绍了Django模板继承的作用和语法、以及模板继承样例,介绍的很详细,感兴趣的朋友可以了解看看,下面让我们一起来学习一下吧!
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部