The Validator Component

The Validator component provides tools to validate values following the JSR-303 Bean Validation specification.

Validator コンポーネントは、JSR-303 Bean Validation 仕様に従って値を検証するためのツールを提供します。

Installation

1
$ composer require symfony/validator

Note

ノート

If you install this component outside of a Symfony application, you must require the vendor/autoload.php file in your code to enable the class autoloading mechanism provided by Composer. Read this article for more details.

このコンポーネントを Symfony アプリケーションの外部にインストールする場合は、Composer が提供するクラス自動ロード メカニズムを有効にするために、コード内に vendor/autoload.php ファイルを必要とする必要があります。詳細については、この記事をお読みください。

Usage

See also

こちらもご覧ください

This article explains how to use the Validator features as an independent component in any PHP application. Read the Validation article to learn about how to validate data and entities in Symfony applications.

この記事では、Validator 機能を任意の PHP アプリケーションで独立したコンポーネントとして使用する方法について説明します。検証の記事を読んで、Symfony アプリケーションでデータとエンティティを検証する方法を学んでください。

The Validator component behavior is based on two concepts:

Validator コンポーネントの動作は、次の 2 つの概念に基づいています。
  • Constraints, which define the rules to be validated;
    検証するルールを定義する制約。
  • Validators, which are the classes that contain the actual validation logic.
    実際の検証ロジックを含むクラスであるバリデーター。

The following example shows how to validate that a string is at least 10 characters long:

次の例は、文字列の長さが 10 文字以上であることを検証する方法を示しています。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
use Symfony\Component\Validator\Constraints\Length;
use Symfony\Component\Validator\Constraints\NotBlank;
use Symfony\Component\Validator\Validation;

$validator = Validation::createValidator();
$violations = $validator->validate('Bernhard', [
    new Length(['min' => 10]),
    new NotBlank(),
]);

if (0 !== count($violations)) {
    // there are errors, now you can show them
    foreach ($violations as $violation) {
        echo $violation->getMessage().'<br>';
    }
}

The validate() method returns the list of violations as an object that implements ConstraintViolationListInterface. If you have lots of validation errors, you can filter them by error code:

Validate() メソッドは、ConstraintViolationListInterface を実装するオブジェクトとして違反のリストを返します。多数の検証エラーがある場合は、エラー コードでフィルタリングできます。
1
2
3
4
5
6
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;

$violations = $validator->validate(/* ... */);
if (0 !== count($violations->findByCodes(UniqueEntity::NOT_UNIQUE_ERROR))) {
    // handle this specific error (display some message, send an email, etc.)
}

Retrieving a Validator Instance

The Validator object (that implements ValidatorInterface) is the main access point of the Validator component. To create a new instance of it, it's recommended to use the Validation class:

Validator オブジェクト (ValidatorInterface を実装する) は、Validator コンポーネントの主要なアクセスポイントです。その新しいインスタンスを作成するには、Validation クラスを使用することをお勧めします。
1
2
3
use Symfony\Component\Validator\Validation;

$validator = Validation::createValidator();

This $validator object can validate simple variables such as strings, numbers and arrays, but it can't validate objects. To do so, configure the Validator as explained in the next sections.

この $validator オブジェクトは、文字列、数値、配列などの単純な変数を検証できますが、オブジェクトを検証することはできません。これを行うには、次のセクションで説明するように theValidator を構成します。

Learn More