定制 choz/request-validation-bundle 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

choz/request-validation-bundle

最新稳定版本:v1.0.7

Composer 安装命令:

composer require choz/request-validation-bundle

包简介

a bundle that's inspired in Laravel request validation

README 文档

README

Quality Gate Status Coverage Maintainability Rating

This is a small library that helps you validate incoming requests with the symfony validation component. knowing how to work with the validation component is a must, Validation doc

Installation

Make sure Composer is installed globally, as explained in the installation chapter of the Composer documentation.

Applications that use Symfony Flex

Open a command console, enter your project directory and execute:

$ composer require choz/request-validation-bundle

Applications that don't use Symfony Flex

Step 1: Download the Bundle

Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:

$ composer require choz/request-validation-bundle

Step 2: Enable the Bundle

Then, enable the bundle by adding it to the list of registered bundles in the config/bundles.php file of your project:

// config/bundles.php

return [
    // ...
    Choz\RequestValidationBundle\ChozRequestValidationBundle::class => ['all' => true],
];

Basic Usage

Request:

<?php

declare(strict_types=1);

namespace App\Request;

use Choz\RequestValidationBundle\Request\BaseRequest;
use Symfony\Component\Validator\Constraints\Collection;
use Symfony\Component\Validator\Constraints\Required;
use Symfony\Component\Validator\Constraints\Type;

class TagCreateRequest extends BaseRequest
{
    protected function rules(): array
    {
        return [
            new Collection([
                'id' => [new Required(), new Type('int')],
                'name' => [new Required(), new Type('string')],
            ]),
        ];
    }
}

Controller:

<?php 

namespace App\Controller;

use App\Request\TagCreateRequest;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\Routing\Annotation\Route;

class TagCreateController extends AbstractController
{
    #[Route('/tags', methods: ['POST'])]
    public function __invoke(TagCreateRequest $request): JsonResponse {
        $id = $request->getInteger('id');
        $name = $request->getString('name');
        // use your values
        return new JsonResponse(['id' => $id, 'name' => $name], status: JsonResponse::HTTP_CREATED);
    }
}

Response with errors from an empty request (code 400):

{
    "message": "The given data failed to pass validation.",
    "errors": {
        "id": [
            "This field is missing."
        ],
        "name": [
            "This field is missing."
        ]
    }
}

Optional

To use it correctly with json request is recommended to install: Symfony JsonRequest Bundle

JSON Request:

{
    "id": "1234",
    "name": 123
}

Will get a JSON Response:

{
    "message": "The given data failed to pass validation.",
    "errors": {
        "id": [
            "This value should be of type int."
        ],
        "name": [
            "This value should be of type string."
        ]
    }
}

Advanced (recommended) usage:

Request:

<?php

declare(strict_types=1);

namespace App\Request;

use Choz\RequestValidationBundle\Request\BaseRequest;
use Symfony\Component\Validator\Constraints\Collection;
use Symfony\Component\Validator\Constraints\Required;
use Symfony\Component\Validator\Constraints\Type;

class TagCreateRequest extends BaseRequest
{
    protected function rules(): array
    {
        return [
            new Collection([
                'id' => [new Required(), new Type('int')],
                'name' => [new Required(), new Type('string')],
            ]),
        ];
    }

    public function getId(): int {
        // return $this->request()->getInt('id'); this works too.
        return $this->getInteger('id');
    }

    public function getName(): string {
        // return $this->request()->getAlpha('name'); this works too.
        return $this->getString('name');
    }
}

Controller:

<?php 

namespace App\Controller;

use App\Request\TagCreateRequest;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\Routing\Annotation\Route;

class TagCreateController extends AbstractController
{
    #[Route('/tags', methods: ['POST'])]
    public function __invoke(TagCreateRequest $request): JsonResponse {
        $id = $request->getId();
        $name = $request->getName();
        // use your values
        return new JsonResponse(['id' => $id, 'name' => $name], status: JsonResponse::HTTP_CREATED);
    }
}

Custom response code:

Override response code:

# config/packages/choz_request_validation.yaml
choz_request_validation:
    response_code: !php/const Symfony\Component\HttpFoundation\Response::HTTP_UNPROCESSABLE_ENTITY # 422

Custom event listener:

Override event listener:

# config/services.yaml
services:
    # ... other services
    choz_request_validation_listener:
        class: App\EventListener\CustomRequestValidationEventListener
        tags:
            - { name: kernel.event_listener, event: kernel.exception }

统计信息

  • 总下载量: 2.65k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 9
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 9
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-10-26