如何在yii中创建客户端自定义规则

时间:2013-09-19 07:30:23

标签: php yii yii-extensions

我想在Yii中使用重置密码功能。为此,我有4个字段,即email,currentPassword,newPassword,newPasswordRepeat。

我在模型中使用了以下规则

array('email, currentPassword, newPassword, newPasswordRepeat', 'required'),
       array('newPasswordRepeat', 'compare', 'compareAttribute'=>'newPassword'),
        array('currentPassword', 'equalPasswords'),

其中equalPasswords是我的用户定义规则,用于检查currentPassword密码是否与我的原始密码匹配。

public function equalPasswords($currentPassword)
{
    $oDbConnection = Yii::app()->db;
    $oCommand = $oDbConnection->createCommand('SELECT * FROM Superadmin_details where email=:email');
    $oCommand->bindParam(':email', Yii::app()->session['email'],PDO::PARAM_STR);
    $user=$oCDbDataReader = $oCommand->queryRow();

    if ($user['password'] != $currentPassword)

    $this->addError($currentPassword, 'Old password is incorrect.');
}

此规则在服务器端出错,即当我单击“提交”按钮时,页面将重新加载,然后显示错误。

我想在客户端显示错误,就像其他错误一样。

我已经在表单中启用了客户端验证。

<?php $form=$this->beginWidget('CActiveForm', array(
      'id'=>'contact-form',
      'enableClientValidation'=>true,

      'clientOptions'=>array(
          'validateOnSubmit'=>true,
      ),
)); ?>

2 个答案:

答案 0 :(得分:0)

尝试更改

$this->addError($currentPassword, 'Old password is incorrect.');

$this->addError('currentPassword', 'Old password is incorrect.');

修改

此外,您需要AJAX验证:

<?php $form=$this->beginWidget('CActiveForm', array(
      'id'=>'contact-form',
      'enableClientValidation'=>true, 'enableAjaxValidation' => true,
      'clientOptions'=>array(
          'validateOnSubmit'=>true,
      ),
)); ?>

并在控制器操作的顶部:

if (array_key_exists('ajax', $_POST) && $_POST['ajax'] === 'contact-form') {
        echo CActiveForm::validate($model);
        Yii::app()->end();
}

答案 1 :(得分:0)

最好的方法是扩展CValidator类。在那里你可以覆盖两个方法validateAttribute和clientValidateAttribute。你需要的是第二个。的 clientValidateAttribute 即可。确保您已启用客户端验证。

'enableClientValidation'=>true,

样品:

class MyValidation extends CValidator
{

protected function validateAttribute($object,$attribute)
{
         //TODO: server side validation
}


public function clientValidateAttribute($object,$attribute)
{
    //TODO: client side javascript
}
}