Laravel中间件怎么创建_Laravel中间件编写使用及实际应用场景介绍

絕刀狂花
发布: 2025-11-25 20:25:02
原创
274人浏览过
Laravel中间件用于处理HTTP请求与响应,可实现权限控制、日志记录等通用逻辑。通过php artisan make:middleware CheckAge命令生成中间件,位于app/Http/Middleware目录,核心为handle方法,接收请求对象和$next回调,可在前后插入前置或后置逻辑。中间件需注册使用,分为三种方式:1. 全局中间件,在app/Http/Kernel.php的$middleware属性中注册,作用于所有请求;2. 路由中间件,在$routeMiddleware数组中定义别名并绑定类,如'check.age' => \App\Http\Middleware\CheckAge::class,再在路由中通过->middleware('check.age')应用;3. 中间件分组,将多个中间件组合成组(如web、api),便于批量调用。典型应用场景包括权限检查(如判断用户是否有编辑权限)、维护模式控制(非管理员重定向至维护页)、请求日志记录(前后记录URL和状态码)以及防止表单重复提交(校验Token)。中间件支持参数传递,例如role:admin可向handle($request, $next, $role)传参,多个参数用逗号分隔。执行顺序按注册顺序正向执行,响应时逆序返回,正确

laravel中间件怎么创建_laravel中间件编写使用及实际应用场景介绍

在Laravel中,中间件是处理HTTP请求和响应的强有力工具。它位于用户请求与应用逻辑之间,可用于过滤、验证、记录日志、权限控制等操作。通过中间件,你可以优雅地实现跨多个路由的通用逻辑。

创建Laravel中间件

使用Artisan命令可以快速生成中间件:

php artisan make:middleware CheckAge

该命令会在app/Http/Middleware目录下生成一个名为CheckAge.php的文件。内容结构如下:

namespace App\Http\Middleware;

use Closure;

class CheckAge
{
    public function handle($request, Closure $next)
    {
        if ($request->age < 18) {
            return redirect('home');
        }

        return $next($request);
    }
}
登录后复制

其中handle方法接收请求对象和下一个中间件回调$next。你可以在调用$next($request)前后插入逻辑,实现“前置”或“后置”处理。

注册和使用中间件

中间件需要注册后才能使用,分为全局中间件、路由中间件和分组中间件三种方式。

1. 全局中间件

app/Http/Kernel.php$middleware属性中添加,会作用于所有请求。

2. 路由中间件

Kernel.php$routeMiddleware数组中注册:

'check.age' => \App\Http\Middleware\CheckAge::class,
登录后复制

然后在路由中使用:

Route::get('/dashboard', function () {
    //
})->middleware('check.age');
登录后复制

3. 中间件分组

可将多个中间件组合为一组,便于复用:

// 在 Kernel.php 中
protected $middlewareGroups = [
    'web' => [
        \App\Http\Middleware\EncryptCookies::class,
        \Illuminate\Session\Middleware\StartSession::class,
        // ...
    ],
];
登录后复制

默认webapi组已内置,可通过middleware('web')应用整组中间件。

实际应用场景示例

Laravel中间件适用于多种常见业务场景:

Jenni AI
Jenni AI

使用最先进的 AI 写作助手为您的写作增光添彩。

Jenni AI 48
查看详情 Jenni AI

权限检查

判断用户是否有访问某页面的权限:

public function handle($request, Closure $next)
{
    if (! auth()->user()?->hasPermission('edit-posts')) {
        abort(403, '无权访问');
    }

    return $next($request);
}
登录后复制

维护模式控制

临时关闭某些功能路径:

if (config('app.maintenance_mode') && ! $request->user()?->isAdmin()) {
    return redirect('/maintenance');
}
登录后复制

日志记录

记录请求信息用于调试或监控:

Log::info('Request started: ' . $request->url());

$response = $next($request);

Log::info('Response sent: ' . $response->getStatusCode());

return $response;
登录后复制

防止重复提交

利用Token机制限制表单重复提交:

if (session('form_token') !== $request->input('token')) {
    return back()->withErrors('非法请求');
}
登录后复制

中间件参数传递

中间件支持接收额外参数。例如定义一个检查用户角色的中间件:

public function handle($request, Closure $next, $role)
{
    if (! $request->user() || $request->user()->role !== $role) {
        return redirect('home');
    }

    return $next($request);
}
登录后复制

注册后在路由中使用:

middleware('role:admin')
登录后复制

多个参数可用逗号分隔:middleware('role:editor,publisher')

基本上就这些。Laravel中间件机制灵活且易于扩展,合理使用能显著提升代码可维护性和安全性。不复杂但容易忽略的是中间件执行顺序——按注册顺序从前到后执行,返回响应时则逆序回传。掌握这一点有助于避免逻辑错乱。

以上就是Laravel中间件怎么创建_Laravel中间件编写使用及实际应用场景介绍的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号