baoziyoo/hyperf-dto-validation

php hyperf dto validation

v1.1.3 2023-08-23 12:45 UTC

This package is auto-updated.

Last update: 2024-04-23 14:23:24 UTC


README

介绍

基于 tw2066/dto 框架改进而来,特别鸣谢tw2066/dto给的灵感

运行环境

  • php >= 8.2
  • hyperf >= 3.0

安装

composer require baoziyoo/hyperf-dto-validation

使用

创建简单dto

<?php

declare(strict_types=1);

namespace Baoziyoo\Hyperf\Example\DTO;

use Baoziyoo\Hyperf\DTO\Validation\Annotation\Rule\Between;
use Baoziyoo\Hyperf\DTO\Validation\Annotation\Rule\Email;
use Baoziyoo\Hyperf\DTO\Validation\Annotation\Rule\In;
use Baoziyoo\Hyperf\DTO\Validation\Annotation\Rule\Integer;
use Baoziyoo\Hyperf\DTO\Validation\Annotation\Rule\Nullable;
use Baoziyoo\Hyperf\DTO\Validation\Annotation\Rule\Required;
use Baoziyoo\Hyperf\DTO\Validation\Annotation\Rule\Validation;

class Address
{
    #[Required(messages: '请输入对应的文本')]
    #[Between(1,5)]
    #[Email]
    #[In(1,5)]
    #[Integer]
    #[Nullable]
    #[Required]
    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;
use Baoziyoo\Hyperf\DTO\Validation\Annotation\Contracts\Valid;

public function add(#[RequestBody] #[Valid] Address $request){}

public function add(#[RequestQuery] #[Valid] Address $request){}

public function fromData(#[RequestFormData] #[Valid] Address $formData){}

public function add(#[RequestBody] #[Valid] DemoBodyRequest $request, #[RequestQuery] #[Valid] DemoQuery $query){}

例子

class DemoController extends AbstractController
{
    public function index(#[RequestQuery] #[Valid] DemoQuery $request): Contact
    {
        $contact = new Contact();
        $contact->name = $request->name;
        var_dump($request);
        return $contact;
    }

    public function add(#[RequestBody] #[Valid] DemoBodyRequest $request, #[RequestQuery] DemoQuery $query)
    {
        var_dump($query);
        return json_encode($request, JSON_UNESCAPED_UNICODE);
    }

    public function fromData(#[RequestFormData] #[Valid] DemoFormData $formData): bool
    {
        $file = $this->request->file('photo');
        var_dump($file);
        var_dump($formData);
        return true;
    }
}