ThinkPHP6项目基操(14.实战部分 中间件处理登录流程)

一、定义中间件

<?php

namespace app\middleware;

class Check
{
    
    
    public function handle($request, \Closure $next)
    {
    
    
        if ($request->param('name') == 'think') {
    
    
            return redirect('index/think');
        }

        return $next($request);
    }
}

中间件类可以随意命名,中间件的入口执行方法必须是handle方法,而且第一个参数是Request对象,第二个参数是一个闭包

二、前置/后置中间件

中间件是在请求具体的操作之前还是之后执行,完全取决于中间件的定义本身。
下面是一个前置行为的中间件:

<?php

namespace app\middleware;

class Before
{
    
    
    public function handle($request, \Closure $next)
    {
    
    
        // 添加中间件执行代码

        return $next($request);
    }
}

下面是一个后置行为的中间件:

<?php

namespace app\middleware;

class After
{
    
    
    public function handle($request, \Closure $next)
    {
    
    
		$response = $next($request);

        // 添加中间件执行代码

        return $response;
    }
}

三、注册中间件

新版的中间件分为全局中间件应用中间件(多应用模式下有效)路由中间件以及控制器中间件四个组。执行顺序分别为:

全局中间件->应用中间件->路由中间件->控制器中间件

1. 全局中间件

全局中间件在app目录下面middleware.php文件中定义,使用下面的方式:

<?php

return [
	\app\middleware\Auth::class
];

中间件的注册应该使用完整的类名,如果已经定义了中间件别名(或者分组)则可以直接使用。全局中间件的执行顺序就是定义顺序。

2. 应用中间件

如果你使用了多应用模式,则支持应用中间件定义,你可以直接在应用目录下面增加middleware.php文件,定义方式和全局中间件定义一样,只是只会在该应用下面生效。

3. 路由中间件

最常用的中间件注册方式是注册路由中间件:

Route::rule('hello/:name','hello')->middleware(\app\middleware\Auth::class);

支持注册多个中间件:

Route::rule('hello/:name','hello')->middleware([\app\middleware\Auth::class, \app\middleware\Check::class]);

4. 控制器中间件

支持为控制器定义中间件,只需要在控制器中定义middleware属性,例如:

<?php
namespace app\controller;

class Index
{
    
    
    protected $middleware = ['auth'];

    public function index()
    {
    
    
        return 'index';
    }

    public function hello()
    {
    
    
        return 'hello';
    }
}

当执行index控制器的时候就会调用auth中间件,一样支持使用完整的命名空间定义。

5. 内置中间件

中间件类 描述
think\middleware\AllowCrossDomain 跨域请求支持
think\middleware\CheckRequestCache 请求缓存
think\middleware\LoadLangPack 多语言加载
think\middleware\SessionInit Session 初始化
think\middleware\FormTokenCheck 表单令牌

这些内置中间件默认都没有定义,你可以在应用的middleware.php文件中、路由或者控制器中定义这些中间件,如果不需要使用的话,取消定义即可。

四、中间件使用 – 后台登录页面跳转流程

在这里插入图片描述
当访问后台主页的时候,如果已经登录(已记录session)则可以进入注意,否则返回登录页面;若访问后台登录页面,如果已经登录(已记录session)则直接跳转到主页,否则进入登录页面。

1. 创建Auth中间件

admin应用文件夹创建middleware文件夹,创建Auth.php中间件文件:

<?php

namespace app\admin\middleware;
use think\Response;

class Auth
{
    
    
    public function handle($request, \Closure $next){
    
    
        // 前置中间件
        if(empty(session(config("admin.session_admin"))) && !preg_match("/login/",$request->pathinfo()) ){
    
    
            return redirect(url('login/index'));
        }
        if(!empty(session(config("admin.session_admin"))) && preg_match("/login\/index/",$request->pathinfo())){
    
    
            return redirect(url('index/index'));
        }

        $response = $next($request);
        // 后置中间件
        return $response;
    }

    public function end(Response $response){
    
    

    }
}

admin.session_admin是在admin/config文件夹下配置文件定义的:
admin/config/admin.php

<?php
return [
    'session_admin' => 'adminUser'
];

2. 注册应用中间件

admin应用目录新建middleware.php

<?php
return [
    \think\middleware\SessionInit::class,
    app\admin\middleware\Auth::class
];

猜你喜欢

转载自blog.csdn.net/zy1281539626/article/details/110881356