”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 掌握 Laravel 中间件:深入指南

掌握 Laravel 中间件:深入指南

发布于2024-07-31
浏览:424

Mastering Middleware in Laravel: An In-Depth Guide

当我在 Web 开发的迷宫中航行时,一个功能始终照亮了我的道路:Laravel 的中间件系统。中间件不只是过滤请求,还可以过滤请求。它改变了应用程序,确保安全性、性能和无缝的用户体验。无论您正在处理身份验证、日志记录还是横切问题,中间件都可以帮助您优雅地管理它。

了解中间件

中间件充当请求响应之间的桥梁,在Web应用程序的请求-响应生命周期中发挥着关键作用。首先,让我们分解一下什么是请求和响应。客户端(通常是用户的浏览器)向服务器发出请求,请求特定资源,例如网页、数据或其他服务。

此请求携带重要信息,包括 HTTP 方法(GET、POST...)、标头以及可能包含数据的正文。一旦服务器收到此请求,它就会处理必要的信息并生成响应。

响应是服务器对客户端请求的答复。它包含请求的状态(例如,成功、失败)、标头和正文,正文通常包括 HTML、JSON 或客户端用于呈现网页或执行进一步操作的其他数据格式。

中间件作为中介发挥作用,可以检查、修改甚至停止这些请求和响应。它在请求到达核心应用程序逻辑之前以及响应发送回客户端之前运行。

我们需要中间件,因为它允许模块化和可重用的代码来处理横切问题,例如身份验证、日志记录和数据操作,而不会使主应用程序逻辑混乱。例如,中间件可以确保只有经过身份验证的用户才能访问某些路由,记录每个请求以进行调试,或者在请求数据到达控制器之前对其进行转换。

创建中间件

在 Laravel 中创建中间件非常简单。您可以使用 Artisan 命令.
生成新的中间件

php artisan make:middleware CheckAge

此命令将在 app/Http/Middleware 目录中创建一个新的 CheckAge 中间件文件。在此文件中,您可以定义每个请求应执行的逻辑。

age 



在此示例中,中间件检查请求中的age属性。如果年龄小于或等于 200,则将用户重定向到 home 路由。否则,它允许请求继续进行。

注册中间件

创建中间件后,您需要将其注册到内核中。内核是 Laravel 应用程序的核心,负责管理 HTTP 请求的整个生命周期。它充当中央枢纽,在请求到达应用程序的路由和控制器之前通过各个中间件层协调请求流。

您可以通过两种方式在 app/Http/Kernel.php 文件中注册中间件:

  1. 全局中间件: 这些中间件在每次请求
    期间运行 你的申请。

  2. 路由中间件:这些中间件可以分配给特定的
    路线。

要将我们的CheckAge中间件注册为路由中间件,请将其添加到内核中的$routeMiddleware数组中:

protected $routeMiddleware = [
    // Other middleware
    'checkAge' => \App\Http\Middleware\CheckAge::class,
];

现在,您可以将此中间件应用到您的路由或路由组中:

Route::get('admin', function () {
    // Only accessible if age > 200
})->middleware('checkAge');

高级中间件技术

Laravel 中的中间件不仅限于简单的检查。以下是一些充分利用中间件的先进技术:

  1. 参数化中间件

中间件可以接受额外的参数。这对于中间件的行为可能根据参数而改变的场景很有用。

public function handle($request, Closure $next, $role)
{
    if (! $request->user()->hasRole($role)) {
        // Redirect or abort
    }

    return $next($request);
}
  1. 分组中间件

您可以将多个中间件分组在一个键下,这有助于将一组中间件应用于多个路由。

protected $middlewareGroups = [
    'web' => [
        \App\Http\Middleware\EncryptCookies::class,
        \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
        \Illuminate\Session\Middleware\StartSession::class,
        // more middleware
    ],
];

将中间件组应用于路由:

Route::middleware(['web'])->group(function () {
    Route::get('/', function () {
        // Uses 'web' middleware group
    });

    Route::get('dashboard', function () {
        // Uses 'web' middleware group
    });
});
  1. 终止中间件

中间件可以定义一个terminate方法,一旦响应发送到浏览器就会调用该方法。这对于日志记录或分析等任务特别有用。

public function terminate($request, $response)
{
    // Log request and response
}

结论

通过掌握中间件,您可以创建不仅安全、高性能而且可维护和可扩展的应用程序。无论您是处理身份验证、日志记录,还是使用自定义参数微调应用程序的行为,中间件都提供了干净而优雅的解决方案。

在您的 Laravel 项目中拥抱中间件的力量,看看它如何改变您管理横切关注点的方式。快乐编码!

版本声明 本文转载于:https://dev.to/cyrilmuchemi/mastering-middleware-in-laravel-an-in-depth-guide-4bde?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    为有效的slug生成首先,该函数用指定的分隔符替换所有非字母或数字字符。此步骤可确保slug遵守URL惯例。随后,它采用ICONV函数将文本简化为us-ascii兼容格式,从而允许更广泛的字符集合兼容性。接下来,该函数使用正则表达式删除了不需要的字符,例如特殊字符和空格。此步骤可确保slug仅包含...
    编程 发布于2025-03-25
  • 如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    How to Resolve "General error: 2006 MySQL server has gone away" While Inserting RecordsIntroduction:Inserting data into a MySQL database can...
    编程 发布于2025-03-25
  • 如何使用node-mysql在单个查询中执行多个SQL语句?
    如何使用node-mysql在单个查询中执行多个SQL语句?
    Multi-Statement Query Support in Node-MySQLIn Node.js, the question arises when executing multiple SQL statements in a single query using the node-mys...
    编程 发布于2025-03-25
  • 如何在Java中执行命令提示命令,包括目录更改,包括目录更改?
    如何在Java中执行命令提示命令,包括目录更改,包括目录更改?
    在java 通过Java通过Java运行命令命令可能很具有挑战性。尽管您可能会找到打开命令提示符的代码段,但他们通常缺乏更改目录并执行其他命令的能力。 solution:使用Java使用Java,使用processBuilder。这种方法允许您:启动一个过程,然后将其标准错误重定向到其标准输出。...
    编程 发布于2025-03-25
  • 如何正确使用与PDO参数的查询一样?
    如何正确使用与PDO参数的查询一样?
    在pdo 中使用类似QUERIES在PDO中的Queries时,您可能会遇到类似疑问中描述的问题:此查询也可能不会返回结果,即使$ var1和$ var2包含有效的搜索词。错误在于不正确包含%符号。通过将变量包含在$ params数组中的%符号中,您确保将%字符正确替换到查询中。没有此修改,PDO...
    编程 发布于2025-03-25
  • 如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    postgresql:为每个唯一标识符在postgresql中提取最后一行,您可能需要遇到与数据集合中每个不同标识的信息相关的信息。考虑以下数据:[ 1 2014-02-01 kjkj 在数据集中的每个唯一ID中检索最后一行的信息,您可以在操作员上使用Postgres的有效效率: id dat...
    编程 发布于2025-03-25
  • 为什么不````''{margin:0; }`始终删除CSS中的最高边距?
    为什么不````''{margin:0; }`始终删除CSS中的最高边距?
    在CSS 问题:不正确的代码: 全球范围将所有余量重置为零,如提供的代码所建议的,可能会导致意外的副作用。解决特定的保证金问题是更建议的。 例如,在提供的示例中,将以下代码添加到CSS中,将解决余量问题: body H1 { 保证金顶:-40px; } 此方法更精确,避免了由全局保证金重置引...
    编程 发布于2025-03-25
  • PHP阵列键值异常:了解07和08的好奇情况
    PHP阵列键值异常:了解07和08的好奇情况
    PHP数组键值问题,使用07&08 在给定数月的数组中,键值07和08呈现令人困惑的行为时,就会出现一个不寻常的问题。运行print_r($月)返回意外结果:键“ 07”丢失,而键“ 08”分配给了9月的值。此问题源于PHP对领先零的解释。当一个数字带有0(例如07或08)的前缀时,PHP将其...
    编程 发布于2025-03-25
  • 找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    如何在mySQL中使用mySql 检索最大计数,您可能会遇到一个问题,您可能会在尝试使用以下命令:理解错误正确找到由名称列分组的值的最大计数,请使用以下修改后的查询: 计数(*)为c 来自EMP1 按名称组 c desc订购 限制1 查询说明 select语句提取名称列和每个名称...
    编程 发布于2025-03-25
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-03-25
  • 如何使用Depimal.parse()中的指数表示法中的数字?
    如何使用Depimal.parse()中的指数表示法中的数字?
    在尝试使用Decimal.parse(“ 1.2345e-02”中的指数符号表示法表示的字符串时,您可能会遇到错误。这是因为默认解析方法无法识别指数符号。 成功解析这样的字符串,您需要明确指定它代表浮点数。您可以使用numbersTyles.Float样式进行此操作,如下所示:[&& && && ...
    编程 发布于2025-03-25
  • 为什么使用Firefox后退按钮时JavaScript执行停止?
    为什么使用Firefox后退按钮时JavaScript执行停止?
    导航历史记录问题:JavaScript使用Firefox Back Back 此行为是由浏览器缓存JavaScript资源引起的。要解决此问题并确保在后续页面访问中执行脚本,Firefox用户应设置一个空功能。 警报'); }; alert('inline Alert')...
    编程 发布于2025-03-25
  • 您如何在Laravel Blade模板中定义变量?
    您如何在Laravel Blade模板中定义变量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配变量对于存储以后使用的数据至关重要。在使用“ {{}}”分配变量的同时,它可能并不总是最优雅的解决方案。幸运的是,Blade通过@php Directive提供了更优雅的方法: $ old_section =“...
    编程 发布于2025-03-25
  • 为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    查询模式实现缺失:解决“无法找到”错误在银光应用程序中,尝试使用LINQ建立错误的数据库连接的尝试,无法找到以查询模式的实现。”当省略LINQ名称空间或查询类型缺少IEnumerable 实现时,通常会发生此错误。 解决问题来验证该类型的质量是至关重要的。在此特定实例中,tblpersoon可能需...
    编程 发布于2025-03-25
  • 版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    在时间戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源于遗留实现的关注,这些限制需要对当前的_timestamp功能进行特定的实现。 创建表`foo`( `Productid` int(10)unsigned not n...
    编程 发布于2025-03-25

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3