中间件简介

中间件简介

什么是中间件?

中间件是一种软件设计模式,可以实现不同系统、应用程序或服务之间的无缝通信和数据交换。它在促进不同组件之间的交互、添加功能和增强整体系统性能方面发挥着至关重要的作用。

问题

在我们之前的项目中,我们遇到了一个问题,已登录的用户在访问注册页面时被要求重新注册。这是由于缺乏中间件实现,导致用户体验不佳。

PHP 中间件

在PHP中,可以使用中间件来处理用户注册和登录功能,确保流畅的用户体验。中间件充当不同组件之间的桥梁,实现无缝通信和数据交换。

if ($_SESSION['user'] ?? false){     标题('位置:/');     出口(); }

它检查用户是否登录。如果没有,则退出脚本以查找经过身份验证的用户。

路由配置

在routes.php文件中,我们可以向路由添加一个“guest”键,将其与中间件关联起来:

$router->get('/register', 'controllers/registration/create.php')->only('guest');

调试唯一方法

要检查项目是否按预期工作,可以在唯一方法中添加调试语句:

仅限公共函数($key){     dd($key); }

它显示错误,因为唯一的方法不能使用 null 值,因为它与 get 方法关联并且不返回任何值。所以我们必须重写这个方法。

重写Add方法

要将所有值返回到唯一的方法,我们需要将router.php文件中的add方法重写为:

公共函数add($method, $uri, $controller) {     $这个->路线[] = [         'uri' => $uri,         '控制器' => $控制器,         '方法' => $方法,         '中间件'=>空     ];     返回$这个; }

现在我们可以看到该项目运行良好。

唯一方法

router.php 文件中唯一需要修改的方法是接受中间件密钥:

美间AI 美间AI

美间AI:让设计更简单

美间AI 45 查看详情 美间AI

仅限公共函数($key){     $this->routes[array_key_last($this->routes)]['middleware']=$key;     返回$这个; }

中间件检查

在create.php文件中,我们可以使用中间件检查用户是否已登录或访客:

if ($route['middleware']==='guest'){     if($_SESSION['用户'] ?? false){         标题('位置:/');         出口();     } } if ($route['中间件']=='auth'){     if(!$_SESSION['user'] ?? false){         标题('位置:/');         出口();     } }

只有经过身份验证的用户才能访问所有页面,而访客只能访问有限的页面。

创建中间件目录

要组织我们的中间件类,请在核心文件夹中创建一个名为 Middleware 的新目录。因为我们必须在某个时刻做出改变才能放松,以节省我们的精力和时间。通过这个我们可以使我们的项目更容易理解。在此创建 3 个不同的类。

认证中间件

Authenticated.php 文件检查用户是否登录,如果为 true 则重定向到主页:

<?php 命名空间 CoreMiddleware; 已验证类{     公共函数句柄(){         if (!$_SESSION['user'] ?? false) {             标题('位置:/');             出口();         }     } }

访客中间件

Guest.php 文件检查用户是否未登录,如果为 true 则重定向到主页:

<?php 命名空间 CoreMiddleware; 类客人{     公共函数句柄(){         if ($_SESSION['user'] ?? false) {             标题('位置:/');             出口();         }     } }

中间件类

Middleware.php 文件使用 MAP 常量将中间件键映射到各自的类。还检查中间件是否存在。如果没有,则向用户显示未捕获的异常以在项目中添加中间件:

 客人::类,         'auth' => 已验证::类     ];     公共静态函数解析($key){         如果(!$键){             返回;         }         $middleware = static::MAP[$key] ??错误的;         if (!$中间件) {             throw new Exception("未找到键 '{$key}' 的匹配中间件。");         }         (新$中间件)->handle();     } }

现在我们可以看到,通过进行这些更改,我们的项目运行良好。

希望您已经清楚地理解了。

以上就是中间件简介的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/529741.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
使用 JavaScript 在另一个页面上显示选定的复选框?
上一篇 2025年11月9日 09:54:20
如何配置CentOS系统以保护Web应用程序免受SQL注入攻击
下一篇 2025年11月9日 09:54:23

相关推荐

  • 正确使用Python verify-email 库处理邮件验证结果

    Python的verify-email库在进行邮件地址验证时,不会通过抛出异常来指示验证失败,而是通过其核心函数verify_email()返回布尔值(True表示有效,False表示无效)。本文将详细指导如何正确地利用这一机制,通过条件判断来处理邮件验证结果,而非尝试捕获不存在的VerifyEma…

    2026年5月10日
    000
  • binance交易平台官网入口 币安官方最新版v3.3.0APP下载安装

    binance交易平台官网入口 币安官方最新版v3.3.0APP下载安装binance交易平台官网入口 币安官方最新版v3.3.0APP下载安装binance交易平台官网入口 币安官方最新版v3.3.0APP下载安装binance交易平台官网入口 币安官方最新版v3.3.0APP下载安装

    欢迎来到币安(binance)的世界!作为全球领先的数字资产交易平台,保障账户安全的第一步就是从官方渠道获取应用程序。本指南将引导您如何安全下载并安装最新版的币安app,并完成后续的注册与安全设置。 币安官网直达: 币安官方app: 一、币安官方App下载与安装 为了确保您的资金安全,请务必通过官方…

    2026年5月10日 用户投稿
    000
  • HTML 与 CSS 联动全解析

    html 和 css 联动可创建交互式且用户友好的 web 页面,通过使用 html 定义页面结构,再用 css 样式化、布局。联动步骤如下:使用 标签将 css 链接到 html 文档。使用选择器在 css 中选择特定的 html 元素。应用样式属性来设置文本、颜色、边框等。 HTML 与 CSS…

    2026年5月10日
    000
  • ThinkPHP框架怎么使用验证器_ThinkPHP数据验证规则与场景配置

    ThinkPHP验证器用于数据校验,提升系统健壮性。通过继承thinkValidate创建自定义验证器,如UserValidate定义用户名、邮箱、密码规则及提示信息;在控制器中实例化并调用check方法进行验证,失败返回错误信息。内置丰富规则:require(必填)、number/integer(…

    2026年5月10日
    100
  • 优化Django REST Framework嵌套序列化实现多模型用户注册

    核心挑战:多模型数据注册与嵌套序列化 在开发复杂的Web应用时,我们经常会遇到一个用户注册流程需要同时创建或更新多个关联模型实例的情况。例如,一个“骑手”注册不仅涉及创建基础的用户账户(CustomUser),还需要创建骑手专属的个人资料(Rider),其中包含车辆信息、服务能力等。传统的嵌套序列化…

    2026年5月10日
    000
  • CxJS中提交表单后重置必填字段验证状态的教程

    本教程旨在解决CxJS应用中表单提交后,即使清空了必填字段,其“已访问”验证边框仍会显示的问题。通过利用ContentResolver组件的动态渲染特性,我们可以在表单提交并清空字段后,强制重新渲染这些字段,从而有效重置其内部的“已访问”状态,确保表单界面在下次输入前保持干净、无验证提示。 引言:C…

    2026年5月10日
    000
  • 币安binanceapp官方下载安装 币安2025安卓最新版本入口地址

    币安binanceapp官方下载安装 币安2025安卓最新版本入口地址币安binanceapp官方下载安装 币安2025安卓最新版本入口地址币安binanceapp官方下载安装 币安2025安卓最新版本入口地址币安binanceapp官方下载安装 币安2025安卓最新版本入口地址

    币安(Binance)是全球领先的数字资产交易平台之一,为用户提供安全、稳定、便捷的数字货币交易服务。它支持多种主流及新兴的数字资产,并提供丰富的交易工具和功能。 本文将为您提供币安2025安卓最新版本的官方下载入口,您只需点击文中给出的下载链接,即可获取官方正版app安装包,开启您的数字资产之旅。…

    2026年5月10日 用户投稿
    000
  • 如何标记html_使用注释标记HTML代码段落【段落】

    可使用HTML注释语法包裹段落以实现标识而不影响渲染,支持添加【段落】等前缀增强可读性,但不可嵌套注释,需用独立注释块替代。 如果您需要在HTML代码中对特定段落进行标识或说明,但又不希望这些标识影响页面渲染效果,则可以使用HTML注释语法将相关代码段落包裹起来。以下是实现此目的的具体方法: 一、使…

    2025年12月23日
    000
  • 优化Django表单用户体验:验证失败时保留输入数据

    本文旨在解决Django表单在提交验证失败后,所有输入字段被清空的问题。通过指导开发者利用Django模板系统渲染表单字段(即使用`{{ form.field }}`),而非手动编写HTML “标签,可以确保用户之前输入的数据在验证失败时自动回填。这极大地提升了用户体验,避免了重复输入,…

    2025年12月23日
    000
  • HTML表单怎么创建_HTML表单的基本结构与创建方法详解

    HTML表单通过标签包裹,使用action和method属性定义提交地址与方式,结合input、select、textarea等控件收集用户数据,配合label和name属性提升可用性与识别性,如注册表单示例所示。 创建HTML表单是网页开发中的基础技能,主要用于收集用户输入的信息,比如登录、注册、…

    2025年12月23日
    000
  • Formik中数字输入字段的范围验证实践

    本文旨在探讨在formik表单中使用`type=”number”`类型字段时,如何有效实现数值范围验证。针对html原生`min`和`max`属性在formik中可能无法提供预期验证效果的问题,我们将重点介绍如何利用强大的yup验证库,结合formik的`validation…

    2025年12月23日
    000
  • 解决Django用户档案关联错误:AppConfig与信号加载最佳实践

    本教程旨在解决Django中`RelatedObjectDoesNotExist`错误,该错误通常发生在用户注册后未能自动创建关联档案(Profile)时。文章将深入分析问题根源——Django信号未被正确加载,并提供两种通过配置`AppConfig`来确保信号被发现和注册的解决方案,同时探讨用户档…

    2025年12月23日
    000
  • Flask 用户注册功能实现:路由配置、数据处理与安全实践

    本文详细探讨了使用 flask 构建用户注册功能时常见的路由配置问题及其解决方案。通过一个实际案例,我们深入分析了 html 表单 action 属性与 flask 路由定义不匹配导致的 404 错误,并提供了正确的配置方法。教程还涵盖了表单数据获取、密码哈希、postgresql 数据库交互以及重…

    2025年12月23日
    000
  • Django Model Choices字段显示问题解决方案

    本文旨在解决Django Model中使用`choices`字段时,在模板中显示对应文本而非存储值的问题。我们将通过示例代码演示如何使用`get_FIELD_display()`方法,方便地在模板中展示可读性更强的选项文本,提升用户体验。 在Django开发中,我们经常使用choices选项来限制字…

    2025年12月23日
    000
  • Flask 应用中实现多 HTML 页面导航:从首页到注册页的路由实践

    本教程详细介绍了如何在 flask 应用中实现多个 html 页面之间的导航。通过 `@app.route` 装饰器和 `render_template` 函数,我们将学习如何从一个 html 页面(如首页)跳转到另一个 html 页面(如注册页),并探讨了不同请求方法的处理方式,以构建结构清晰、交…

    2025年12月23日
    000
  • HTML图片替代文本怎么写_HTML图片alt属性最佳实践

    alt属性用于准确传达图片信息或功能,提升可访问性与SEO。应简洁描述内容与上下文,如“手冲咖啡壶正在将热水倒入滤杯中”;装饰性图片留空(alt=””);避免冗余词、关键词堆砌和过度描述;功能性图标需说明作用,如搜索图标写“搜索”;包含关键细节但聚焦核心,让视觉障碍者也能理解…

    2025年12月23日
    000
  • 分步用户数据收集下的数据库设计与参照完整性实践

    本文探讨了在分步收集用户数据并存储于不同数据库表时,如何通过主键和外键实现表间连接,并强调了将数据整合到单一表作为更优解决方案的数据库设计原则与实践。文章提供了具体的数据库表结构设计示例和SQL查询语句,旨在帮助读者构建高效且具备参照完整性的数据库系统。 分步数据收集的挑战与数据库设计考量 在用户注…

    2025年12月22日
    000
  • 根据用户输入邮箱显示/隐藏按钮:jQuery 实现指南

    本文将介绍如何使用 jQuery 实现一个常见的用户界面交互:仅当用户在指定输入框中输入正确的邮箱地址时,才显示某个按钮(例如“删除账户”按钮)。我们将提供完整的代码示例,并详细解释实现逻辑,帮助你理解并应用到自己的项目中,提升用户体验。 核心思路 实现这个功能的关键在于: 获取用户的邮箱地址: 从…

    2025年12月22日
    000
  • 利用HTML required 属性实现表单必填项验证与页面跳转控制

    本文介绍如何利用HTML5的required属性实现客户端表单必填项验证,确保用户填写所有必要信息后才能提交表单并进行页面跳转。同时,文章强调了结合pattern属性进行更精细验证的重要性,并提醒开发者务必进行服务器端验证,以保障数据安全和业务逻辑的严谨性。 在网页开发中,表单是用户与网站交互的重要…

    2025年12月22日
    000
  • 解决PHP变量在HTML输入框中显示不全的问题:值属性引号的重要性

    当PHP从MySQL数据库获取的字符串变量(如包含空格的姓名)在HTML表单的input字段中显示不完整时,常见原因是HTML value属性缺少正确的引号。本文将详细解释这一问题,并通过代码示例展示如何通过为value属性添加双引号来确保PHP变量的完整值被正确渲染,从而避免数据截断,确保用户编辑…

    2025年12月22日
    000

发表回复

登录后才能评论
关注微信