## 中间件 中间件主要用于拦截或过滤应用的请求,并进行必要的业务处理,通常使用在登录验证的场景。 ## 定义中间件 源码中默认自带了两个中间件,一个前置,一个后置。 >[success] - 中间件类名必须带 Middleware 后缀 ### 前置中间件 如果想拦截请求不往下执行,只需在 $next() 前 return 响应内容即可。 [>> 到 GitHub 查看范例 <<](https://github.com/mix-php/mix/blob/master/applications/http/src/Middleware/BeforeMiddleware.php) ### 后置中间件 [>> 到 GitHub 查看范例 <<](https://github.com/mix-php/mix/blob/master/applications/http/src/Middleware/AfterMiddleware.php) ## 注册中间件 ### 全局中间件 [路由组件配置](https://github.com/mix-php/mix/blob/master/applications/http/config/main_coroutine.php#L144) 中的 `middleware` 配置项目可配置全局中间件,全局中间件是全局有效的,对任何路由都有效。 ~~~ // 全局中间件 'middleware' => ['After'], ~~~ >[info] 配置时不需要加 Middleware 后缀。 ### 路由中间件 我们也可以在路由中为某一个路由规则配置要执行的中件间,如下: ~~~ // 路由规则 'rules' => [ // 一级路由 '/{controller}/{action}' => ['{controller}', '{action}', 'middleware' => ['Before']], ], ~~~ ### 如果我们需要排除某些路由规则不使用中间件 只需要在 **带通配符规则的前面** 增加一条不带 middleware 配置的路由。 ~~~ // 路由规则 'rules' => [ // 一级路由中URL /profile/userinfo 不使用中间件 '/profile/userinfo' => ['Profile', 'Userinfo'], // 一级路由 '/{controller}/{action}' => ['{controller}', '{action}', 'middleware' => ['Before']], ], ~~~