2010-03-05 22 views
5

añado esta clase a la biblioteca/Mi/Validar/PasswordConfirmation.phpConfirmación de la contraseña en Zend Framework

<?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['password']) 
       && ($value == $context['password'])) 
      { 
       return true; 
      } 
     } elseif (is_string($context) && ($value == $context)) { 
      return true; 
     } 

     $this->_error(self::NOT_MATCH); 
     return false; 
    } 
} 
?> 

Luego de crear dos campos en mi forma de esta manera:

 $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', 'password_confirm'); 
    $userPasswordRepeat->setLabel('Password repeat: '); 
    $userPasswordRepeat->setRequired('true'); 
    $userPasswordRepeat->addPrefixPath('My_Validate','My/Validate','validate'); 

    $userPasswordRepeat->addValidator('PasswordConfirmation'); 
    $this->addElement($userPasswordRepeat) 

todo es bueno pero cuando envío el formulario, siempre aparece el mensaje "La confirmación de la contraseña no concuerda". ¿Qué está mal en mi código

+0

Aquí está una manera de hacer la validación de contraseña utilizando los validadores de Zend (me di cuenta de que puede n O ha sido posible cuando se hizo esta pregunta): http://stackoverflow.com/questions/347856/zend-form-how-to-check-2-fields-are-identical/3782388#3782388 –

Respuesta

2

Creo que es posible que desee $context['user_password'] como que es el nombre de su "primera" elemento de la contraseña

3

Hay una forma mejor de hacerlo. En el formulario de poner el validador idéntica en el campo passoword confirmación, y luego simplemente sobrescribir $ form-> isValid() para establecer el valor de ser validado:

public function __construct($options = NULL) 
{ 
    // ... 
    $confirm->addValidator('Identical'); 
    // ... 
} 
public function isValid($data) 
{ 
    $confirm = $this->getElement('confirm_password'); 
    $confirm->getValidator('Identical')->setToken($data['password']); 
    return parent::isValid($data); 
} 
9

Una manera menos elegante y más fácil de hacerlo:

$password = new Zend_Form_Element_Password('password'); 
    $password->setLabel('Password:') 
      ->addValidator('StringLength', false, array(6,24)) 
      ->setLabel('Choose your password:') 
      ->setRequired(true); 

    $password2 = new Zend_Form_Element_Password('password-confirm'); 
    $password2->setLabel('Confirm:') 
      ->addValidator('StringLength', false, array(6,24)) 
      ->setLabel('Confirm your password:') 
      ->addValidator(new Zend_Validate_Identical($_POST['password'])) 
      ->setRequired(true); 
+0

Gracias Marcel por ti útil y breve reproducción – 3ehrang

+0

y si tiene alguna experiencia en partialloop, infórmeme. – 3ehrang

17

no es necesario para anular el Zend_Form-> método isValid o utilizar el superglobal $ _POST, mira esto:

$frmPassword1=new Zend_Form_Element_Password('password'); 
$frmPassword1->setLabel('Password') 
    ->setRequired('true') 
    ->addFilter(new Zend_Filter_StringTrim()) 
    ->addValidator(new Zend_Validate_NotEmpty()); 

$frmPassword2=new Zend_Form_Element_Password('confirm_password'); 
$frmPassword2->setLabel('Confirm password') 
    ->setRequired('true') 
    ->addFilter(new Zend_Filter_StringTrim()) 
    ->addValidator(new Zend_Validate_Identical('password')); 
+0

No anulé zend_form es un método válido. Solo agregué mi propio validador. – 3ehrang