Phalcon PHP-表单和模型验证

Phalcon支持2个验证组件:

Phalcon\Validation\Validator
Phalcon\Mvc\Model\Validator

我不知道如何在我的情况下使用它们.我有以下注册表:

> csrf
>用户名
>密码
>重复密码
>电子邮件
>重复电子邮件
>提交按钮

我创建了一个注册表,如下所示:

class RegistrationForm extends \Phalcon\Forms\Form
{
    public function initialize()
    {
        $csrf = new \Phalcon\Forms\Element\Hidden('csrf');
        $csrf->addValidator(new \Phalcon\Validation\Validator\Identical(array(
            'value' => $this->security->getSessionToken(),
            'message' => 'CSRF validation failed'
        )));

        $username = new \Phalcon\Forms\Element\Text('username');
        $username->addFilter('trim');
        $username->addValidator(new PresenceOf(array(
            'message' => 'Username is required.',
        )));
        $username->addValidator(new StringLength(array(
            'min' => 6,
            'messageMinimum' => 'Username must be at least 6 characters.'
        )));

        // ...
    }
}

这是我的控制器/动作:

class UserController extends \Phalcon\Mvc\Controller
{
    public function registerAction()
    {
        $form = new RegistrationForm();
        if ($this->request->isPost()) {
            if ($form->isValid($this->request->getPost())) {
                // Test only
                var_dump($this->request->getPost());
                exit;
            } else {
                // Test only
                foreach ($form->getMessages() as $message) {
                    echo $message, '<br/>';
                }
                exit;
            }
        }

        $this->view->form = $form;
    }
}

>何时使用模型验证器,反之亦然?
>我们可以将它们结合在一起吗?
>我想知道使用模型和非模型验证器来检查csrf,相同的密码,用户名和电子邮件唯一性的正确方法,以执行此注册操作.

谢谢您帮忙!

解决方法:

您可以在将数据发送到数据库之前使用模型验证器.通常,您的POST和模型中的数据(类型/结构/层次结构)会有所不同,例如,一个表单接收与两个模型相关的输入,这两个模型都会被更新.因此,接收到POST数据后,您要检查其是否有效,并且保存两个独立模型后,还需要检查它们是否有效.

Phalcon有一个validation component,它是所有验证的基类.它的工作方式与上述代码中的表单验证完全相同.

我对Phalcon中整个验证业务的实现方式不感兴趣-它不能为您提供严格的控制,并且验证和验证器之间存在很大的依赖关系.但是,它在形式和模型验证的范围内做得很好.没有重复使用相同验证器的简洁方法,但是there are some know attempts可以发挥您的想象力:)

要实施注册操作,您仅应使用表单验证器过滤掉用户输入.我可能是错的,但是Phalcon模型会根据字段中的元数据自动验证数据,因此您只需担心POST输入. Big working with models文档详细介绍了该主题,我确定您已经去过那里.

上一篇:PHP-Laravel 5.2条件验证


下一篇:C#-ASP.NET身份-未调用自定义角色验证