oskarstark / symfony-http-responder
这个库提供了一个Symfony响应类,可以用来渲染模板、返回json或文件,以及重定向到路由/URL。
1.5.0
2023-12-03 20:38 UTC
Requires
- php: >=8.2
- symfony/http-foundation: ^5.4 || ^6.3 || ^7.0
- symfony/routing: ^5.4 || ^6.3 || ^7.0
- symfony/serializer: ^5.4 || ^6.3 || ^7.0
- twig/twig: ^2.13 || ^3.0
Requires (Dev)
- ergebnis/php-cs-fixer-config: ^5.0
- phpstan/phpstan: ^0.12.82
- phpunit/phpunit: ^9.5.3
- symfony/psr-http-message-bridge: ^2.1
Suggests
- symfony/psr-http-message-bridge: PSR-15 Request Handler Interface.
README
这个库提供了一个Symfony响应类,可以用来渲染模板、返回json或文件,以及重定向到路由/URL。
这个库旨在在未继承自AbstractController的控制器中使用。
安装
composer require oskarstark/symfony-http-responder
用法
渲染模板
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Responder; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Routing\Annotation\Route; #[Route('/index', name: 'app_index')] final class IndexController { public function __construct( private Responder $responder, ) { } public function __invoke(): Response { return $this->responder->render('index.html.twig'); } }
返回JSON
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Responder; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Routing\Annotation\Route; #[Route('/api', name: 'app_api')] final class ApiController { public function __construct( private Responder $responder, ) { } public function __invoke(): Response { $data = [ 'foo' => 42, ]; return $this->responder->json($data); } }
返回文件
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Responder; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Routing\Annotation\Route; #[Route('/download', name: 'app_download')] final class DownloadController { public function __construct( private Responder $responder, ) { } public function __invoke(): Response { // You can either provide a filepath $file = '/app/invoices/invoice.pdf'; // or an SplFileObject $file = new \SplFileObject('/app/invoices/invoice.pdf'); return $this->responder->file($file); } }
重定向到URL
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Responder; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Routing\Annotation\Route; #[Route('/redirect', name: 'app_redirect')] final class RedirectController { public function __construct( private Responder $responder, ) { } public function __invoke(): Response { return $this->responder->redirect('http://google.com'); } }
重定向到路由
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Responder; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Routing\Annotation\Route; #[Route('/redirect', name: 'app_redirect')] final class RedirectController { public function __construct( private Responder $responder, ) { } public function __invoke(): Response { return $this->responder->route('app_my_route'); } }
PSR-7和PSR-15支持
当使用symfony/psr-http-message-bridge包时,Symfony可以使用PSR-7 Response Interface实例来响应,具体请参阅这篇博客文章。
# config/packages/oskarstark_symfony_http_responder.yaml services: # ... OskarStark\Symfony\Http\Psr7Responder: null
渲染模板
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Psr7Responder; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use Symfony\Component\Routing\Annotation\Route; final class RedirectHandler implements RequestHandlerInterface { public function __construct( private Psr7Responder $responder, ) { } #[Route('/index', name: 'app_index')] public function handle(ServerRequestInterface $request): ResponseInterface { return $this->responder->render('index.html.twig'); } }
返回JSON
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Psr7Responder; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use Symfony\Component\Routing\Annotation\Route; final class RedirectHandler implements RequestHandlerInterface { public function __construct( private Psr7Responder $responder, ) { } #[Route('/api', name: 'app_api')] public function handle(ServerRequestInterface $request): ResponseInterface { return $this->responder->json($data); } }
返回文件
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Psr7Responder; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use Symfony\Component\Routing\Annotation\Route; final class RedirectHandler implements RequestHandlerInterface { public function __construct( private Psr7Responder $responder, ) { } #[Route('/download', name: 'app_download')] public function handle(ServerRequestInterface $request): ResponseInterface { // You can either provide a filepath $file = '/app/invoices/invoice.pdf'; // or an SplFileObject $file = new \SplFileObject('/app/invoices/invoice.pdf'); return $this->responder->file($file); } }
重定向到URL
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Psr7Responder; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use Symfony\Component\Routing\Annotation\Route; final class RedirectHandler implements RequestHandlerInterface { public function __construct( private Psr7Responder $responder, ) { } #[Route('/redirect', name: 'app_redirect')] public function handle(ServerRequestInterface $request): ResponseInterface { return $this->responder->redirect('http://google.com'); } }
重定向到路由
<?php declare(strict_types=1); namespace App\Controller; use OskarStark\Symfony\Http\Psr7Responder; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use Symfony\Component\Routing\Annotation\Route; final class RedirectHandler implements RequestHandlerInterface { public function __construct( private Psr7Responder $responder, ) { } #[Route('/redirect', name: 'app_redirect')] public function handle(ServerRequestInterface $request): ResponseInterface { return $this->responder->route('app_my_route'); } }