0

次のようなカスタム ルールがあるとします。

<?php

class CheckFoo extends \Respect\Validation\Rules\AbstractRule
{
    public function validate($input)
    {
        if ($input == 'foo')
            return true;
        else
            return false;       
    }
}

class CheckFooException extends \Respect\Validation\Exceptions\ValidationException
{
    public static $defaultTemplates = [
        self::MODE_DEFAULT => [
            self::STANDARD => '{{name}} must be foo',
        ],
        self::MODE_NEGATIVE => [
            self::STANDARD => '{{name}} must not be foo',
        ],
    ];
}

これは正常に機能しますが、このルール内に追加のルールを追加することは可能ですか? 説明すると、次のようなことが可能です。

class CheckFoo extends \Respect\Validation\Rules\AbstractRule
{
    public function validate($input)
    {
        if (strlen($input) != 3)
            return false;

        if ($input == 'foo')
            return true;
        else
            return false;
    }
}

トリガーされたCheckFooException場合にカスタムエラーメッセージを定義するにはどうすればよいですか?(strlen($input) != 3)

4

1 に答える 1

1

使用しているライブラリ、特にValidationExceptionクラスと の実装を調べると、検証中にルール クラスで宣言されたプロパティに Exception クラスからAttributeExceptionアクセスできるはずです。ValidationException::getParam($propertyName)そのようです:

class CheckFoo extends \Respect\Validation\Rules\AbstractRule
{
    public $reason;

    public function validate($input)
    {
        if (strlen($input) != 3) {
            $this->reason = 'length';
            return false;
        }

        if ($input !== 'foo') {
            $this->reason = 'content';
            return false;
        }
        return true;

    }
}

ValidationException::chooseTemplate次に、次のように method を実装/オーバーライドしてアクセスします。

class CheckFooException extends \Respect\Validation\Exceptions\ValidationException
{
    const INVALID_LENGTH = 0;
    const INVALID_NAME = 1;

    public static $defaultTemplates = [
        self::MODE_DEFAULT => [
            self::INVALID_NAME => '{{name}} must be foo',
            self::INVALID_LENGTH => '{{name}} must be 3 characters long',
        ],
        self::MODE_NEGATIVE => [
            self::INVALID_NAME => '{{name}} must not be foo',
            self::INVALID_LENGTH => '{{name}} must not be 3 characters long',
        ],
    ];

    public function chooseTemplate()
    {
        return 'length' === $this->getParam('reason')
            ? self::INVALID_LENGTH
            : self::INVALID_NAME;
    }
}

テスト:

v::checkFoo()->check('FOO'); // => "FOO" must be foo
v::checkFoo()->check('foox'); // => "foox" must be 3 characters long

または、2 つの異なるルールを専用のメッセージと組み合わせることができます (または、長さが些細な場合は、ライブラリによって既に提供されているものを使用します)。

于 2018-11-18T20:22:41.007 に答える