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文档详细介绍了该主题,我确定您已经去过那里.
标签:phalcon,validation,php 来源: https://codeday.me/bug/20191121/2054369.html