0

0

PHP框架如何使用中间件处理请求 PHP框架中间件应用的基础教程

看不見的法師

看不見的法師

发布时间:2025-08-16 23:31:01

|

647人浏览过

|

来源于php中文网

原创

要定义一个php中间件,需创建实现middlewareinterface的类并实现process方法,该方法接收请求和处理器参数,可对请求进行处理或拦截;1. 在laravel中通过kernel.php注册全局或路由中间件,并在路由中用middleware()应用;2. 在symfony中通过服务配置监听kernel.request等事件实现中间件;3. 在slim中使用$app->add()注册中间件;中间件用于在请求前后执行逻辑,典型场景包括身份验证、日志记录、请求响应修改、缓存、csrf保护和速率限制;中间件执行顺序由注册顺序决定,应明确依赖、避免副作用、使用命名空间和单元测试来防止冲突;编写可测试中间件应遵循依赖注入、接口隔离和单一职责原则,使用phpunit模拟请求和处理器对象进行测试;在中间件中通过方法访问请求信息,并使用withattribute或withheader等方法创建新对象以安全修改请求和响应。

PHP框架如何使用中间件处理请求 PHP框架中间件应用的基础教程

PHP框架使用中间件,就像高速公路上的收费站,每个请求都要经过,你可以检查车辆(请求),修改车辆(请求),或者直接拒绝车辆通过(阻止请求)。它提供了一种优雅的方式来在请求到达你的控制器之前或之后,对请求进行预处理或后处理。

使用中间件,其实就是定义一个类,实现特定的接口,然后在框架的配置中注册它。

中间件本质上就是一个可执行的管道,请求像水一样流过,中间件对它进行过滤、处理,最终到达目的地。

立即学习PHP免费学习笔记(深入)”;

如何定义一个PHP中间件?

定义中间件,你需要创建一个类,这个类通常会实现一个接口(例如,

Psr\Http\Server\MiddlewareInterface
),或者定义一个特定的方法(例如,
handle
)。这个方法接收请求对象和下一个中间件的闭包作为参数。

namespace App\Middleware;

use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
use Psr\Http\Server\MiddlewareInterface;
use Slim\Psr7\Response; // 假设你使用Slim框架

class AuthMiddleware implements MiddlewareInterface
{
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): Response
    {
        // 在这里进行身份验证逻辑
        $token = $request->getHeaderLine('Authorization');

        if ($token !== 'valid_token') {
            $response = new Response();
            $response->getBody()->write('Unauthorized');
            return $response->withStatus(401);
        }

        // 调用下一个中间件或路由处理程序
        $response = $handler->handle($request);
        return $response;
    }
}

这段代码展示了一个简单的身份验证中间件。它从请求头中获取

Authorization
token,如果 token 无效,则返回 401 Unauthorized 响应。否则,它调用下一个中间件或路由处理程序。

如何在不同的PHP框架中注册和应用中间件?

不同的框架有不同的注册和应用中间件的方式。

  • Laravel: 在 Laravel 中,你可以在

    app/Http/Kernel.php
    文件中注册全局中间件、路由中间件或中间件组。也可以在路由定义中使用
    middleware()
    方法应用中间件。

    // app/Http/Kernel.php
    protected $middleware = [
        \App\Http\Middleware\TrustProxies::class,
        \App\Http\Middleware\PreventRequestsDuringMaintenance::class,
        \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
        \App\Http\Middleware\TrimStrings::class,
        \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
    ];
    
    protected $routeMiddleware = [
        'auth' => \App\Http\Middleware\Authenticate::class,
        'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
        'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
        'can' => \Illuminate\Auth\Middleware\Authorize::class,
        'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
        'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
        'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
        'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
    ];
    
    // 在路由中使用
    Route::get('/profile', function () {
        // 只有经过身份验证的用户才能访问...
    })->middleware('auth');
  • Symfony: 在 Symfony 中,你可以创建服务并使用标签

    kernel.event_listener
    注册中间件。然后,你可以监听
    kernel.request
    kernel.response
    事件来执行中间件逻辑。

    ECTouch移动商城系统
    ECTouch移动商城系统

    ECTouch是上海商创网络科技有限公司推出的一套基于 PHP 和 MySQL 数据库构建的开源且易于使用的移动商城网店系统!应用于各种服务器平台的高效、快速和易于管理的网店解决方案,采用稳定的MVC框架开发,完美对接ecshop系统与模板堂众多模板,为中小企业提供最佳的移动电商解决方案。ECTouch程序源代码完全无加密。安装时只需将已集成的文件夹放进指定位置,通过浏览器访问一键安装,无需对已有

    下载
    # config/services.yaml
    services:
        App\EventListener\RequestListener:
            tags:
                - { name: kernel.event_listener, event: kernel.request, method: onKernelRequest }
  • Slim: 在 Slim 中,你可以使用

    $app->add()
    方法注册中间件。Slim 遵循 PSR-15 中间件规范。

    // index.php
    use App\Middleware\AuthMiddleware;
    
    $app = new \Slim\App();
    $app->add(new AuthMiddleware());
    
    $app->get('/hello/{name}', function ($request, $response, $args) {
        $name = $args['name'];
        $response->getBody()->write("Hello, $name");
        return $response;
    });
    
    $app->run();

中间件在PHP框架中扮演什么角色,有哪些典型应用场景?

中间件就像请求处理流程中的拦截器,允许你在请求到达控制器之前或之后执行代码。典型应用场景包括:

  • 身份验证和授权: 验证用户身份,检查用户是否有权访问特定资源。
  • 日志记录: 记录请求和响应信息,用于调试和审计。
  • 请求修改: 修改请求参数,例如,将字符串转换为整数。
  • 响应修改: 修改响应内容,例如,添加 HTTP 头。
  • 缓存: 缓存响应,提高性能。
  • CSRF 保护: 防止跨站请求伪造攻击。
  • 速率限制: 限制请求频率,防止滥用。

如何处理中间件执行顺序,以及如何避免中间件之间的冲突?

中间件的执行顺序通常取决于它们注册的顺序。一般来说,先注册的中间件先执行。为了避免冲突,你需要仔细设计中间件的逻辑,确保它们不会互相干扰。

  • 明确依赖关系: 如果一个中间件依赖于另一个中间件的结果,确保它们按照正确的顺序执行。
  • 避免副作用: 尽量避免中间件产生副作用,例如,修改全局状态。
  • 使用命名空间: 使用命名空间可以避免类名冲突。
  • 单元测试: 编写单元测试可以帮助你发现中间件之间的冲突。

如何编写可测试的中间件,以及如何进行单元测试?

编写可测试的中间件,你需要遵循一些最佳实践:

  • 依赖注入: 使用依赖注入可以使你的中间件更容易测试。
  • 接口: 使用接口可以使你的中间件更容易模拟。
  • 单一职责原则: 每个中间件应该只负责一个任务。

你可以使用 PHPUnit 或其他测试框架进行单元测试。你需要模拟请求对象和下一个中间件的闭包,然后断言中间件的行为是否符合预期。

// tests/Middleware/AuthMiddlewareTest.php
use PHPUnit\Framework\TestCase;
use App\Middleware\AuthMiddleware;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
use Slim\Psr7\Response;

class AuthMiddlewareTest extends TestCase
{
    public function testUnauthorized()
    {
        $request = $this->createMock(ServerRequestInterface::class);
        $request->method('getHeaderLine')->willReturn(''); // 没有token

        $handler = $this->createMock(RequestHandlerInterface::class);

        $middleware = new AuthMiddleware();
        $response = $middleware->process($request, $handler);

        $this->assertEquals(401, $response->getStatusCode());
        $this->assertEquals('Unauthorized', (string) $response->getBody());
    }

    public function testAuthorized()
    {
        $request = $this->createMock(ServerRequestInterface::class);
        $request->method('getHeaderLine')->willReturn('valid_token');

        $handler = $this->createMock(RequestHandlerInterface::class);
        $handler->method('handle')->willReturn(new Response()); // 模拟下一个中间件或路由处理程序

        $middleware = new AuthMiddleware();
        $response = $middleware->process($request, $handler);

        $this->assertEquals(200, $response->getStatusCode()); // 假设下一个处理程序返回 200
    }
}

这段代码展示了如何测试

AuthMiddleware
。它模拟了请求对象和下一个中间件的闭包,然后断言中间件的行为是否符合预期。

如何在中间件中访问和修改请求和响应对象?

中间件接收请求对象作为参数,你可以使用请求对象的方法来访问请求头、请求体、查询参数等。

public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): Response
{
    $method = $request->getMethod(); // 获取请求方法
    $uri = $request->getUri(); // 获取 URI
    $queryParams = $request->getQueryParams(); // 获取查询参数
    $body = $request->getBody(); // 获取请求体

    // 修改请求
    $request = $request->withAttribute('user_id', 123); // 添加属性

    // 调用下一个中间件或路由处理程序
    $response = $handler->handle($request);

    // 修改响应
    $response = $response->withHeader('X-Custom-Header', 'value');

    return $response;
}

你可以使用

with*()
方法来创建新的请求或响应对象,而不是直接修改原始对象。这可以避免副作用,并使你的代码更容易测试。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2524

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1600

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1493

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1416

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3.1万人学习

React 教程
React 教程

共58课时 | 3.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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