baoziyoo / hyperf-dto
php hyperf dto
v1.1.7
2024-11-26 08:52 UTC
Requires
- php: >=8.2
- hyperf/di: ~3.0.0
- hyperf/http-server: ~3.0.0
- hyperf/validation: ~3.0.0
- netresearch/jsonmapper: ~4.0.0
- phpdocumentor/reflection-docblock: ^5.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- mockery/mockery: ^1.0
- phpstan/phpstan: ^0.12
- phpunit/phpunit: >=7.0
- symfony/var-dumper: ^5.1
README
介绍
基于 tw2066/dto 框架改进而来,特别鸣谢tw2066/dto给的灵感
运行环境
- php >= 8.2
- hyperf >= 3.0
安装
composer require baoziyoo/hyperf-dto
使用
创建简单dto
<?php declare(strict_types=1); namespace Baoziyoo\Hyperf\Example\DTO; class Address { public string $street; public float $float; public int $int; /** @var array<int,string> */ public array $array; public LoginTokenTypeEnum $loginTokenTypeEnum; public ?City $city = null; } --- class City { public string $name; } --- enum LoginTokenTypeEnum: string { case jwt = 'jwt'; case password = 'password'; }
引用
注意: 一个方法,不能同时注入RequestBody和RequestFormData
use Baoziyoo\Hyperf\DTO\Annotation\Contracts\RequestBody; use Baoziyoo\Hyperf\DTO\Annotation\Contracts\RequestQuery; use Baoziyoo\Hyperf\DTO\Annotation\Contracts\RequestFormData; // 获取Body参数 public function add(#[RequestBody] Address $request){} // 获取GET参数 public function add(#[RequestQuery] Address $request){} // 获取表单请求 public function fromData(#[RequestFormData] Address $formData){} // 获取Body参数和GET参数 public function add(#[RequestBody] DemoBodyRequest $request, #[RequestQuery] DemoQuery $query){}
例子
class DemoController extends AbstractController { public function index(#[RequestQuery] DemoQuery $request): Contact { $contact = new Contact(); $contact->name = $request->name; var_dump($request); return $contact; } public function add(#[RequestBody] DemoBodyRequest $request, #[RequestQuery] DemoQuery $query) { var_dump($query); return json_encode($request, JSON_UNESCAPED_UNICODE); } public function fromData(#[RequestFormData] DemoFormData $formData): bool { $file = $this->request->file('photo'); var_dump($file); var_dump($formData); return true; } }