什么是中间件
对于中间件的理解,你可以把它看作一种拦截器,或者说是一种过滤器。它提供了一种方便的机制来检查和过滤 HTTP 请求。当你设置了中间件后,在你执行了 HTTP 请求要进入到应用程序之前,需要先通过这个中间件里设定的验证逻辑。通过验证可以继续进入到应用程序,如果验证失败会阻止 HTTP 请求,跳转指定的页面或者特定的逻辑。例如身份验证,如果用户未通过身份验证,中间件会将用户重定向到应用程序的登录屏幕。但是,如果用户通过了身份验证,中间件将允许请求进一步进入应用程序。
中间件是如何运行的
Laravel 应用程序的所有请求的入口点都是 public\index.php 文件,这里加载框架和服务器(Apache/Nginx)配置的发起点,这里也是启动中间件配置的起点,如下图:
Laravel 框架内核会依次加载 config\app.php 和 app\Http\Kernel.php。在config\app.php 文件里它会加载框架核心组件、注册服务提供者等,这里我们只需要关注的provider 的注册,因为启动中间件依靠的是 RouteServiceProvider。Kernel.php 文件是中间件的配置文件,里面处理中间件的影响范畴和注册信息。下面我们分别分析这两个文件:
app.php
我们在 config\App.php 文件里可以找到配置的所有 provider,当应用程序开始运行后会启动里面所有的 provider,也包括我们关注的 RouteServiceProvider,如下图:
打开 RouteServiceProvider 文件后可以看到,boot() 方法里配置了在 Kernel.php 里设定的 web 组 和 api 组,这两个中间件组的所指定的 route 文件(Laravel 项目里所有的路由配置文件都放在 Routes文件夹下),如下:
public function boot()
{
$this->configureRateLimiting();
$this->routes(function () {
/* prefix() 此设定为路由名前缀,
* 例如你的路由名设置为 home,那你在浏览器的路由名就为 api/home
*/
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->group(base_path('routes/api.php'));
Rout