我想在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,
),
)); ?>
答案 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
}
}