作为一款流行的PHP框架,Laravel 在开发过程中经常使用Middleware中间件。在本文中,我们将涵盖使用 Laravel 中间件的基础知识以及如何创建和使用自定义 Middleware 中间件。
Laravel Middleware 中间件是一种用于过滤 HTTP 请求的机制。它们通常用于处理复杂的 HTTP 请求逻辑,例如验证用户身份、授予访问权限或记录请求日志。
Laravel自带了一些内置的 Middleware 中间件,例如:
- auth: 用于检查用户是否已登录。
- throttle: 用于限制用户在一定时间内可以进行的请求次数。
在本文中,我们将使用 Laravel 自带的 Middleware 中间件来演示这些基本概念。此外,我们还将创建自定义 Middleware 中间件,以演示如何编写自己的中间件。
使用内置 Middleware 中间件
让我们首先看一下如何在 Laravel 中使用内置 Middleware 中间件。要使用内置中间件,您只需要将其添加到$routeMiddleware数组中。在appHttpKernel.php文件中,可以找到该数组。这个数组包含了所有默认的中间件,并且每个中间件都有一个与其关联的键名。
例如,我们可以通过使用auth键名来启用认证中间件:
protected $routeMiddleware = [
'auth' => IlluminateAuthMiddlewareAuthenticate::class,
];
Laravel 还支持对中间件进行参数化传递。例如,如果我们要使用throttle限制用户在60秒内最多可以访问5个页面,可以这么写:
protected $routeMiddleware = [
'throttle' => IlluminateRoutingMiddlewareThrottleRequests::class.':5,60',
];
注意:这里的数字顺序与throttle中间件构造函数的参数顺序相反。这是因为Laravel支持用字符串传递参数。
创建自定义 Middleware 中间件
除了使用预先定义的 Middleware 中间件外,Laravel 还支持创建自己的中间件。让我们看一下如何创建并使用自定义 Middleware 中间件。
为了演示这点,我们将创建一个名为MyMiddleware 的自定义中间件。这个中间件只需要在请求处理之前输出文本即可。
首先,我们需要通过artisan命令创建一个中间件类:
php artisan make:middleware MyMiddleware
然后,我们需要打开app/Http/Middleware/MyMiddleware.php文件,并在handle方法中编写我们的中间件逻辑:
<?php
namespace AppHttpMiddleware;
use Closure;
class MyMiddleware
{
public function handle($request, Closure $next)
{
echo "My middleware is working!";
return $next($request);
}
}
在这个例子中,我们只需要在处理请求之前先输出一条文本。这个文本可以是任何内容,例如您可以输出一些调试信息、日志或错误信息等等。
在编写了我们的 Middleware 中间件之后,我们需要将其注册到 Laravel 应用程序中。在app/Http/Kernel.php文件中,我们可以将我们的中间件类名称添加到$routeMiddleware数组中。这将使中间件可用于路由和控制器。
protected $routeMiddleware = [
'mymiddleware' => AppHttpMiddlewareMyMiddleware::class,
];
注意:如您所见,我们将MyMiddleware类的名称作为键名,以便在后面的路由和控制器中使用。
要使用这个新的中间件,只需要将其添加到照常的middleware数组中即可。在我们的例子中,我们可以将其添加到网站的路由中: