Yii2确认密码无效

时间:2016-06-29 11:00:32

标签: yii2 yii2-basic-app yii2-user yii2-validation

我正在尝试构建一个注册表单,当我不使用重复密码时它工作正常,它保存到模型,但当我使用我的重复密码时,它只是不让我将它们保存在数据库中。我的代码如下。

SimUser.php文件

public function rules()
    {
        return [
            [['user_email', 'user_password_hash','company_id','user_fname', 'user_lname','agree'], 'required'],
            ['agree','required','requiredValue' => 1, 'message' => ''],
            ['user_password_hash_repeat', 'compare','compareAttribute' => 'user_password_hash','message' => 'Password don\'t match'],
            [['agree'],'safe'],
            [['user_password_hash_repeat'],'safe'],
            [['user_company', 'user_suspended', 'user_deleted'], 'integer'],
            [['user_created'], 'safe'],
            [['user_email'], 'string', 'max' => 255],
            [['user_password_hash'], 'string', 'max' => 72],
            [['user_fname', 'user_lname'], 'string', 'max' => 45],
            [['user_auth_key'], 'string', 'max' => 32],
            [['user_access_token'], 'string', 'max' => 100],
        ];
    }

我的控制器操作:网站/注册

 public function actionSignup()
    {
        $company = new Company(); 
        $company->load(Yii::$app->request->post());
        $company->save();


        $model = new SimUser();
        if ($model->load(Yii::$app->request->post())) {
            $model->setPassword($model->user_password_hash);
            $model->generateAuthKey();
            $model->company_id =  $company->company_id;
            //var_dump($model); exit();
            $model->save();
            $model = new LoginForm();
            return $this->render('login',[
                'model' => $model,
            ]);
        }
        return $this->render('signup', [
            'model' => $model,
            'company' => $company,
        ]);
    }

这里我将保存公司模型中的comany名称以及用户表中的其他名称。

我的观点文件: signup.php

<h1>Sign Up</h1> 
                <?= $form->field($model, 'user_fname')->textInput(['placeholder'=>'First Name*','class'=>'form-control col-lg-4'])->label(false);?>
                <?= $form->field($model, 'user_lname')->textInput(['placeholder'=>'Last Name*','class'=>'form-control col-lg-4'])->label(false); ?>
                <?= $form->field($model,'user_email')->textInput(['placeholder'=>'Email*','class'=>'form-control col-lg-4'])->label(false); ?>
                <?= $form->field($model, 'user_password_hash')->passwordInput(['placeholder'=>'Password'])->label(false); ?>
                <?= $form->field($model, 'user_password_hash_repeat')->passwordInput(['placeholder'=>'Confirm Password*','class'=>'form-control col-lg-4'])->label(false); ?>
                <?= $form->field($company, 'company_name')->textInput(['placeholder'=>'Company Name*','class'=>'form-control col-lg-4'])->label(false); ?>
                <?php echo $form->field($model, 'agree')->checkbox(); ?>
                <div class="form-group"> 
                    <?= Html::submitButton('Sign Up', ['class' => 'pull-left padding-0 btn btn-success', 'name' => 'signup-button']) ?>
                </div>

该公司的错误消息没有,它始终存在..附加输出为图像click here 你们中的任何人都可以帮我解决这个问题吗?在此先感谢!!

Company.php    * /

public function rules()
{
    return [
        [['company_name'], 'required'],
        [['company_name'], 'string', 'max' => 75],
    ];
}

2 个答案:

答案 0 :(得分:0)

在控制器中已将公司保存在beginnig中。因此,每次我加载页面它都是在我提交之前保存的。因此,错误仍然存​​在。

要更改的代码:

$company = new Company(); 
        $model = new SimUser(['scenario' => SimUser::SCENARIO_REGISTER]);
        if ($model->load(Yii::$app->request->post()) && $company->load(Yii::$app->request->post())) {

            $company->save();

            $model->setPassword($model->user_password_hash);
            $model->generateAuthKey();
            $model->company_id =  $company->company_id;            
            $model->save();

所以1个问题已经解决了..无法解决确认密码问题!如果有人可以发布错误是什么会有帮助吗?

答案 1 :(得分:0)

关于重复密码

为什么对 user_password_hash_repeat 使用安全规则?通常对于确认密码字段,使用某些功能将其与密码字段匹配。这就是我在项目中的表现:

// string in validation rules
['passconf', 'matchPassword']

// rule for confirm password field
public function matchPassword($attribute)
{
    if ($this->password != $this->passconf) {
        $this->addError($attribute, "Confirm Password doesn't match the Password");
    }
}