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.
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.
The Validator component behavior is based on two concepts:
- 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:
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:
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:
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.
Learn More ¶
- Metadataメタデータ
- Loading Resourcesリソースのロード
- Validation検証
- How to Create a Custom Validation Constraintカスタム検証制約を作成する方法
- How to Apply only a Subset of all Your Validation Constraints (Validation Groups)すべての検証制約 (検証グループ) のサブセットのみを適用する方法
- How to Validate Raw Values (Scalar Values and Arrays)生の値 (スカラー値と配列) を検証する方法
- How to Sequentially Apply Validation Groups検証グループを順次適用する方法
- How to Handle Different Error Levelsさまざまなエラー レベルの処理方法
- How to Translate Validation Constraint Messages