Zend framework Zend#u Dojo#u表单密码文本框验证程序don';行不通

Zend framework Zend#u Dojo#u表单密码文本框验证程序don';行不通,zend-framework,dojo,passwords,token,validation,Zend Framework,Dojo,Passwords,Token,Validation,我是zf的新手,最近我使用zend_dojo_表单制作了一个注册表表单,有两个passwordtextbox元素,一个用于输入密码,另一个用于确认前一个,然后我使用验证程序“token”但失败,这是我代码的一部分 $this->addElement('PasswordTextBox','password',array( 'label'=>'password:', 'required'=>true, 'tri

我是zf的新手,最近我使用zend_dojo_表单制作了一个注册表表单,有两个passwordtextbox元素,一个用于输入密码,另一个用于确认前一个,然后我使用验证程序“token”但失败,这是我代码的一部分

$this->addElement('PasswordTextBox','password',array(
            'label'=>'password:',
            'required'=>true,
            'trim'=>true,
            'regExp'=>'^[a-z0-9]{6,18}$',
            'invalidMessage'=>'password should be 6-18',
            'Decorators' => array(
                'DijitElement',
                'Errors',
                array(array('data'=>'HtmlTag'),array('tag'=>'td','align'=>'left')),
                array('Label',array('tag'=>'td')),
                array(array('row'=>'HtmlTag'),array('tag'=>'tr','align'=>'right'))
                )
            )
        );
    //$this->addElement($password1);

    $this->addElement('PasswordTextBox','password2',array(
        'label'=>'confirm password:',
        'required'=>true,
        'trim'=>true,
        //'regExp'=>'^[a-z0-9]{6,18}$',
        'validators'=>array(array('identical',false,array('token'=>'password'))),
        'invalidMessage'=>'the password you enter not the same',
        'Decorators' => array(
            'DijitElement',
            'Errors',
            array(array('data'=>'HtmlTag'),array('tag'=>'td','align'=>'left')),
            array('Label',array('tag'=>'td')),
            array(array('row'=>'HtmlTag'),array('tag'=>'tr','align'=>'right'))
            )
        )
    );

以下是一个应具有功能性的示例:

class Application_Form_Register extends Zend_Dojo_Form {

    public function init() {
            $this
                            ->setOptions(array('name' => 'registerForm'))
                            // username
                            ->addElement('TextBox', 'first_name', array(
                                    'filters' => array('StringTrim', 'StringToLower'),
                                    'id' => 'name_register',
                                    'required' => true,
                                    'label' => 'Fornavn(e):',
                            ))
                            ->addElement('TextBox', 'last_name', array(
                                    'filters' => array('StringTrim', 'StringToLower'),
                                    'id' => 'surname_register',
                                    'label' => 'Efternavn:',
                            ))
                            ->addElement('ValidationTextBox', 'email', array(
                                    'filters' => array('StringTrim', 'StringToLower'),
                                    'validators' => array(
                                            'EmailAddress',
                                            array('StringLength', false, array(3, 60)),
                                    ),
                                    'regExp' => "^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$",
                                    'id' => 'email_register',
                                    'required' => true,
                                    'label' => 'E-mail:',
                            ))
                            //password
                            ->addElement('PasswordTextBox', 'password', array(
                                    'filters' => array('StringTrim'),
                                    'validators' => array(
                                            'Alnum',
                                            array('StringLength', false, array(6, 20)),
                                    ),
                                    'regExp' => "^([a-zA-Z0-9_\-!-=]){4,32}$",
                                    'tooltipPosition' => 'above',
                                    'invalidMessage' => 'Krav til password: mellem 4 og 32 i længde og kun karakterer som tal, bogstaver eller blandt [ _-!"#%&/()=] er tilladt',
                                    'id' => 'password_register',
                                    'onKeyDown' => 'arguments[0].keyCode == dojo.keys.ENTER && application.submitRegistration(dijit.byId(\'registerForm\'));',
                                    'required' => true,
                                    'label' => 'Password:',
                            ))
                           ->addElement('PasswordTextBox', 'password_confirm', array(
                                    'filters' => array('StringTrim'),
                                    'validators' => array(
                                            'Alnum',
                                            array('StringLength', false, array(6, 20)),
                                    ),
                                    'id' => 'passwordconfirm_register1',
                                    'onKeyDown' => 'arguments[0].keyCode == dojo.keys.ENTER && application.submitRegistration(dijit.byId(\'registerForm\'));',
                                    'required' => true,
                                    'label' => 'Gentag password:',
                            ))

                           ->addElement('PasswordTextBox', 'password_confirm', array(
                                    'filters' => array('StringTrim'),
                                    'validators' => array(
                                            'Alnum',
                                            array('StringLength', false, array(6, 20)),
                                    ),
                                    'id' => 'passwordconfirm_register2',
                                    'onKeyDown' => 'arguments[0].keyCode == dojo.keys.ENTER && application.submitRegistration(dijit.byId(\'registerForm\'));',
                                    'required' => true,
                                    'label' => 'Gentag password:',
                            ))
                            ->addElement('Hidden', 'action', array(
                                    'id' => 'action_register',
                                    'value' => 'register',
                            ))
                            ->addElement('Button', 'foo', array(
                                    'id' => 'foo_register',
                                    'onClick' => 'application.submitRegistration(dijit.byId(\'registerForm\'))',
                                    'label' => 'Register'
                                            )
            );
            $this->_decorate();

    }
    // renders nulled empty labels and adds classnames, related to element name
    protected function _decorate() {
            $this->setDecorators(array(
                    'FormElements',
                    array('HtmlTag', array('tag' => 'div', 'class' => 'zend_form_contents')),
                    'DijitForm'
            ));

            foreach ($this->getElements() as $el) {

                    $el->addDecorator('HtmlTag', array('tag' => 'div', 'class' => $el->getName() . '-wrap'));
                    if ($el->helper == 'Button')
                            continue;
                    else if (strlen(trim($el->getLabel())) == 0)
                            $el->addDecorator('Label', array('tag' => null));
                    else
                            $el->addDecorator('Label', array('tag' => 'div', 'class' => $el->getName() . '-label'));
            }
    }
}
和第二个pwd字段,具有相同的属性,但具有不同的验证器

 ->addElement('PasswordTextBox', 'password_2_', array(
       // strictly serverside, only accepts alphanumerical pwds lengths 6 through 20
       'validators' => array(
           array('identical',false,array('token'=>'password'))
       ),
       // widget id
       'id' => 'passwordconfirm_register2',
       'required' => true,
       // in theory, we would define 'validator' in programmatic construct of
       // the validationtextbox. but this will not work with the way Zend handles dojo
       // 'validator' => 'function(value, constraints) { return "BAD PRACTICE" }'
  ));
  // add javascript code to run onload and to extend the 'register2' properly
  $this->getElement()
      ->getView()
      ->headScript()
      ->appendFile($baseUrl . '/js/Validator.js');
到目前为止,passwordconfirm\u register2小部件中只有“required”在客户端被验证。让我们修复标记工厂在上面几行中针对“不良做法”所做的操作。删除该行并添加javascript代码,其中包含:

// file: baseUrl/js/Validator.js
dojo.addOnLoad(function() {
  dijit.byId('passwordconfirm_register2').validate = function(value, constraints) {

     if(dijit.byId('passwordconfirm_register1').get("value") != value) {
            this.invalidMessage = "Passwords are not identical";
            return false;
     }

     return true

  });
});

谢谢你的回复,你的代码很好。但也许我没有把我的问题说清楚,实际上,我的问题是关于密码确认。我使用zend_form be4,它通过使用“相同”验证器(如:array('idential',false,array('token'=>'password'))工作良好,然后我切换到zend_dojo,它并不像我想的那样,所以有什么帮助吗?啊哈..那么问题是,您没有区分服务器端和客户端验证。dijit.form.ValidationTextbox没有“相同”参数。我们在formelements中定义的“Validator”是100%服务器端验证程序;用于postba仅限ck例程。我将在dojo World中指定一个“链接”表单字段。似乎添加外部.js文件对我来说相当困难,我尝试您的帖子:$this->getElement()->getView()->headScript()->appendFile($baseUrl./js/Validator.js'));但我仍然不能正确地理解它,我使用IE devoper工具,在标记中看不到.js的ref。我相当确定,'headScript'viewhelper将这些参数带到appendFile。但是它可能会查找文件本身,如果不存在,则在生成的代码中省略脚本标记。尝试插入完整的相对url('/'前缀).
$baseUrl
是必须设置的ofc:)
// file: baseUrl/js/Validator.js
dojo.addOnLoad(function() {
  dijit.byId('passwordconfirm_register2').validate = function(value, constraints) {

     if(dijit.byId('passwordconfirm_register1').get("value") != value) {
            this.invalidMessage = "Passwords are not identical";
            return false;
     }

     return true

  });
});