Phalcon \ Mvc \ Model :: validation()和非模型验证器 [英] Phalcon\Mvc\Model::validation() and non-model validators

查看:113
本文介绍了Phalcon \ Mvc \ Model :: validation()和非模型验证器的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用Model :: validation()调用进行模型验证.

I am working on Model validation using Model::validation() call.

看起来Model :: validate()仅接受 Phalcon \ Mvc \ Model \ Validator 名称空间中的验证器,并在使用 Phalcon \ Validation \ Validator 时崩溃:

It looks like Model::validate() only accepts validators from Phalcon\Mvc\Model\Validator namespace and crashes when Phalcon\Validation\Validator are used:

class User extends Phalcon\Mvc\Model
{
    protected $email = 'invalid @email.*';

    public function validation()
    {
        // Validator from Model namespace
        $this->validate(new Phalcon\Mvc\Model\Validator\Uniqueness(array(
            "field"   => "email",
            "message" => "The email is already registered"
        )));

        // Validator from Validation namespace - causes "BadMethodCallException" - "Wrong number of parameters".
        $this->validate(new Phalcon\Validation\Validator\Between(array(
            "field"   => "counter",
            'minimum' => 10,
            'maximum' => 20,
            "message" => "Invalid value"
        )));   

        $validationHasFailed = $this->validationHasFailed();
        return $validationHasFailed != true;
    }
}

这会导致 BadMethodCallException-错误的参数数量错误.

我的下一个想法是更改代码,如下所示:

My next thought was to alter the code as follows:

class User extends Phalcon\Mvc\Model
{
    protected $email = 'invalid @email.*';

    public function validation()
    {
        // Omitting Uniqueness validator.

        $validation = new Phalcon\Validation();
        $validation->add('email', new Phalcon\Validation\Validator\Email);
        $this->validate($validation);

        $validationHasFailed = $this->validationHasFailed();
        return $validationHasFailed != true;
    }
}

但是,该代码无法检测到电子邮件字段的无效值(未发生验证错误).

However, that code fails to detect invalid value of email field (no validation error occurs).

同时,以下电子邮件验证将按预期进行:

At the same time, the following email validation works as expected:

$validation = new Validation();
$validation->add('email', new EmailValidator());
$messages = $validation->validate([
    'email' => 'bad email @...',
], 'email');

问题:

我可以在Model :: validation()调用中使用非模型验证器吗?

Can I use non-Model validators in Model::validation() call?

谢谢!

推荐答案

好,我的问题的答案是否".

Well, the answer to my question is NO.

这是一种解决方法:

public function validation()
{
    /**
     * Validate email address.
     *
     * Looks like there's a difference between model- and non-model validators.
     */
    $emailField = 'email';
    $validation = new Phalcon\Validation;
    $validation->add($emailField, new Phalcon\Validation\Validator\Email);

    /**
     * @var Phalcon\Validation\Message\Group
     */
    if (sizeof($messages = $validation->validate([
        $emailField => $this->email,
    ], $emailField))) {
        $message = new Phalcon\Mvc\Model\Message('Invalid email address.', $emailField);
        $this->appendMessage($message);
    } else {
        /**
         * Only when non-model validators don't fail, get on with model validators
         *
         * Validate email uniqueness.
         */
        $this->validate(new Phalcon\Mvc\Model\Validator\Uniqueness([
            'field' => $emailField,
            'message' => 'The email is already registered'
        ]));

    }
    $validationHasFailed = $this->validationHasFailed();

    return $validationHasFailed != true;
}

希望有人觉得这有用.

这篇关于Phalcon \ Mvc \ Model :: validation()和非模型验证器的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆