delolmo / symfony-router
PSR-15 中间件,用于使用 symfony/routing 组件并将路由属性存储在请求中。
2.1
2023-11-17 16:12 UTC
Requires
- php: ^8.1
- php-http/discovery: ^1.19
- psr/http-message: ^1.0 || ^2.0
- psr/http-server-middleware: ^1.0
- symfony/config: ^6.2
- symfony/psr-http-message-bridge: ^2.3
- symfony/routing: ^6.2
Requires (Dev)
- cakephp/http: ^5.0
- doctrine/coding-standard: ^10.0
- equip/dispatch: ^2.0
- ergebnis/composer-normalize: ^2.29
- infection/infection: ^0.26
- laminas/laminas-diactoros: ^3.3
- php-parallel-lint/php-parallel-lint: ^1.3
- phpstan/phpstan: ^1.10
- phpstan/phpstan-deprecation-rules: ^1.1
- phpstan/phpstan-mockery: ^1.1
- phpstan/phpstan-phpunit: ^1.3
- phpstan/phpstan-strict-rules: ^1.5
- phpunit/phpunit: ^10.4
- rector/rector: ^0.15
- roave/security-advisories: dev-latest
- squizlabs/php_codesniffer: ^3.7
- vimeo/psalm: ^5.15
This package is auto-updated.
Last update: 2024-09-15 17:44:15 UTC
README
PSR-15 中间件,用于使用 symfony/routing 组件并将路由属性存储在请求中。
要求
- PHP ^8.1
- PSR-7 http 库
- PSR-17 http 工厂
安装
此软件包可以通过 Composer 以 delolmo/symfony-router 的方式安装和自动加载。
composer require delolmo/symfony-router
您可能还想安装 php-http/discovery 以自动检测已知的 PSR-17 HTTP 工厂实现。
示例
考虑使用 Symfony 的 PhpFileLoader 从以下文件加载路由定义
# routes.php use App\Controller\BlogController; use Symfony\Component\Routing\RouteCollection; use Symfony\Component\Routing\Route; $routes = new RouteCollection(); $routes->add('blog_list', new Route('/blog', array( 'request-handler' => [BlogController::class, 'list'] ))); $routes->add('blog_show', new Route('/blog/{slug}', array( 'request-handler' => [BlogController::class, 'show'] ))); return $routes;
对于此示例,我们将使用 middlewares/utils
作为符合 PSR-15 的调度器。有关更多 PSR-15 实现,请参阅 链接。
此示例使用基本匿名函数来打印路由的属性
use Laminas\Diactoros\Response\HtmlResponse; use Laminas\Diactoros\ServerRequest; use Middlewares\Utils\Dispatcher; use Middlewares\Utils\Factory; use Symfony\Component\Config\FileLocator; use Symfony\Component\Routing\Loader\PhpFileLoader; use Symfony\Component\Routing\RequestContext; use Symfony\Component\Routing\Router; $fileLocator = new FileLocator(array(__DIR__)); $router = new Router( new PhpFileLoader($fileLocator), 'routes.php', array('cache_dir' => __DIR__ . '/cache'), new RequestContext('/') ); $factory = Factory::getRequestFactory(); $dispatcher = new Dispatcher([ new DelOlmo\Middleware\SymfonyRouterMiddleware($router, $factory), function($request, $next) { return new HtmlResponse(json_encode($request->getAttributes())); } ]); // Try matching a /blog request $response = $dispatcher->dispatch(new ServerRequest([], [], '/blog')); // Will return {"_route": "blog_list", "request-handler" => ["App\Controller\BlogController", "list"]} $c->get('emitter')->emit($response); // Try matching a /blog/hello-world request $response = $dispatcher->dispatch(new ServerRequest([], [], '/blog/hello-world')); // Will return {"_route": "blog_show", "request-handler" => ["App\Controller\BlogController", "show"], "slug" => "hello-world"} $c->get('emitter')->emit($response);
选项
构造函数接受两个参数
__construct( \Symfony\Component\Routing\Router $router, \Psr\Http\Message\ResponseFactoryInterface $responseFactory )
要使用的路由实例和创建错误响应(如 404
或 405
)的 PSR-17 工厂。