Как проверить поле пароля в форме zend?
В моей форме я пытаюсь проверить, что пользователь заполняет одно и то же значение оба раза (чтобы убедиться, что они не сделали ошибку). Я думаю, что для Zend_Validate_Identical
, но я не совсем уверен, как его использовать. Вот что у меня до сих пор:
$this->addElement('password', 'password', array(
'label' => 'Password:',
'required' => true,
'validators' => array(
'Identical' => array(What do I put here?)
)
));
$this->addElement('password', 'verifypassword', array(
'label' => 'Verify Password:',
'required' => true,
'validators' => array(
'Identical' => array(What do I put here?)
)
));
Нужно ли мне это на обоих элементах? Что я помещаю в массив?
Ответы
Ответ 1
Для чего его ценность, поддержка сравнения двух одинаковых полей формы в модели была добавлена к выпуску 1.10.5. Я написал короткий учебник по этому вопросу, к которому вы можете получить доступ, используя приведенную ниже ссылку, но в сущности, рефакторинг Zend_Validate_Identical был реорганизован, чтобы принять имя поля формы в качестве входного. Например, чтобы сравнить значения полей формы pswd и confirm_pswd, вы присоедините валидатор к confirm_pswd следующим образом:
$confirmPswd->addValidator('Identical', false, array('token' => 'pswd'));
Работает как шарм.
См. Проверка идентичных паролей с помощью Zend Framework для более полного примера.
Ответ 2
Я не могу проверить это на данный момент, но я думаю, что это может сработать:
$this->addElement('password', 'password', array(
'label' => 'Password:',
'required' => true
));
$this->addElement('password', 'verifypassword', array(
'label' => 'Verify Password:',
'required' => true,
'validators' => array(
array('identical', true, array('password'))
)
));
Ответ 3
Через два дня я нашел правильный ответ, следуя за мной шаг за шагом:
шаг 1:
создайте файл PasswordConfirmation.php
в корневой директории вашего проекта с помощью этого пути:
yourproject/My/Validate/PasswordConfirmation.php
с этим содержанием ниже:
<?php
require_once 'Zend/Validate/Abstract.php';
class My_Validate_PasswordConfirmation extends Zend_Validate_Abstract
{
const NOT_MATCH = 'notMatch';
protected $_messageTemplates = array(
self::NOT_MATCH => 'Password confirmation does not match'
);
public function isValid($value, $context = null)
{
$value = (string) $value;
$this->_setValue($value);
if (is_array($context)) {
if (isset($context['user_password'])
&& ($value == $context['user_password']))
{
return true;
}
}
elseif (is_string($context) && ($value == $context)) {
return true;
}
$this->_error(self::NOT_MATCH);
return false;
}
}
?>
шаг 2:
Добавьте два поля в вашу форму:
//create the form elements user_password
$userPassword = $this->createElement('password', 'user_password');
$userPassword->setLabel('Password: ');
$userPassword->setRequired('true');
$this->addElement($userPassword);
//create the form elements user_password repeat
$userPasswordRepeat = $this->createElement('password', 'user_password_confirm');
$userPasswordRepeat->setLabel('Password repeat: ');
$userPasswordRepeat->setRequired('true');
$userPasswordRepeat->addPrefixPath('My_Validate', 'My/Validate', 'validate');
$userPasswordRepeat->addValidator('PasswordConfirmation', true, array('user_password'));
$this->addElement($userPasswordRepeat);
теперь наслаждайтесь своим кодом
Ответ 4
class My_Validate_PasswordConfirmation extends Zend_Validate_Abstract
{
const NOT_MATCH = 'notMatch';
protected $_messageTemplates = array(
self::NOT_MATCH => 'Password confirmation does not match'
);
public function isValid($value, $context = null)
{
$value = (string) $value;
$this->_setValue($value);
if (is_array($context)) {
if (isset($context['password_confirm'])
&& ($value == $context['password_confirm']))
{
return true;
}
} elseif (is_string($context) && ($value == $context)) {
return true;
}
$this->_error(self::NOT_MATCH);
return false;
}
}
http://framework.zend.com/manual/en/zend.form.elements.html
Ответ 5
$token = Zend_Controller_Front::getInstance()->getRequest()->getPost('password');
$confirmPassword->addValidator(new Zend_Validate_Identical(trim($token)))
->addFilter(new Zend_Filter_StringTrim())
->isRequired();
Используйте вышеуказанный код внутри класса, который расширяет zend_form.
Ответ 6
Мне удалось заставить его работать со следующим кодом:
В моей форме я добавляю Identical validator только для второго элемента:
$this->addElement('text', 'email', array(
'label' => 'Email address:',
'required' => true,
'filters' => array('StringTrim'),
'validators' => array('EmailAddress')
));
$this->addElement('text', 'verify_email', array(
'label' => 'Verify Email:',
'required' => true,
'filters' => array('StringTrim'),
'validators' => array('EmailAddress', 'Identical')
));
И в контроллере перед вызовом isValid()
:
$validator = $form->getElement('verify_email')->getValidator('identical');
$validator->setToken($this->_request->getPost('email'));
Я не знаю, есть ли более элегантный способ сделать это, не добавляя этот код в контроллер. Дайте мне знать, если есть лучший способ сделать это.
Ответ 7
С Zend Framework 1.10 код, необходимый для проверки равенства двух полей с помощью Zend Form и Zend Validate:
$form->addElement('PasswordTextBox',
'password',
array('label' => 'Password')
);
$form->addElement('PasswordTextBox',
'password_confirm',
array('label' => 'Confirm password',
'validators' => array(array('Identical', false, 'password')),
)
);
В массиве validators элемента password_confirm
вы можете заметить, что валидатор Identical
передается как массив, семантика этого массива: i) имя валидатора, ii) разрыв цепи при отказе, iii) опции валидатора
Как вы можете видеть, возможно получить имя поля вместо получения значения.