Php 模型场景yii上的验证规则冲突

Php 模型场景yii上的验证规则冲突,php,validation,yii,Php,Validation,Yii,我有如下模型的验证规则 public function rules() { // NOTE: you should only define rules for those attributes that // will receive user inputs. //post of step 1 if (isset($_POST['yt0'])) { return array( array('EmailAddr

我有如下模型的验证规则

public function rules()
{
    // NOTE: you should only define rules for those attributes that
    // will receive user inputs.
    //post of step 1
    if (isset($_POST['yt0']))
    {
        return array(
                array('EmailAddress,', 'required','message' =>  Yii::t('message', 'USERNAME_REQUIRED')),
                array('Password,', 'required','message' =>  Yii::t('message', 'PASSWORD_REQUIRED')),
                array('confirmPassword,', 'required','message' => Yii::t('message', 'CONFIRM_PASSWORD_REQUIRED')),
                array('Password','length', 'max' => 100, 'min' => 6, 'tooShort' => Yii::t('message', 'PASSWORD_LENGTH')),
                array('confirmPassword', 'compare', 'compareAttribute'=>'Password','message' => Yii::t('message', 'PASSWORD_COMPARE')),
                array('EmailId,', 'required','message' => Yii::t('message', 'EMAILID_REQUIRED')),
                array('EmailId','email','message'=>Yii::t('message', 'EMAILID_VALID')),
                array('chapterCode,', 'required','message' => Yii::t('message', 'CHAPTERCODE_REQUIRED')),
                array('verifyCode,', 'required','message' =>Yii::t('message', 'VERIFYCODE_REQUIRED')),
                array('verifyCode', 'captcha', 'allowEmpty'=>!CCaptcha::checkRequirements(),'caseSensitive'=>true,'message' =>Yii::t('message', 'VERIFYCODE_INCORRECT') ),
                array('EmailAddress', 'unique','className'=>'User','attributeName'=>'EmailAddress','message'=>Yii::t('message', 'EMAILID_UNIQUE')),
                array('PersonId', 'unique','className'=>'User','attributeName'=>'PersonId','message'=>"Person already exists."),
                array('FailedLoginCount', 'safe'),
        );
    }   elseif (isset($_POST['yt1']))
    {
        return array(
                array('EmailAddress,', 'required','message' => Yii::t('message', 'USERNAME_REQUIRED')),
                array('Password,', 'required','message' =>  Yii::t('message', 'PASSWORD_REQUIRED')),
                array('FailedLoginCount', 'safe'),

        );
    }elseif (isset($_POST['savecontact'])||$this->memBelongsto==0)
    {
        return array(
                array('EmailAddress,', 'required','message' => Yii::t('message', 'USERNAME_REQUIRED')),
                array('Password,', 'required','message' =>  Yii::t('message', 'PASSWORD_REQUIRED')),
                array('confirmPassword', 'required','message' => Yii::t('message', 'CONFIRM_PASSWORD_REQUIRED')),
                array('Password','length', 'max' => 100, 'min' => 6,'tooShort' => Yii::t('message', 'PASSWORD_LENGTH')),
                array('confirmPassword', 'compare', 'compareAttribute'=>'Password','message' => Yii::t('message', 'PASSWORD_COMPARE')),
                array('EmailId,', 'required','message' => Yii::t('message', 'EMAILID_REQUIRED'),'except'=>'datavalid'),
                array('EmailId','email','message'=>Yii::t('message', 'EMAILID_VALID'),'except'=>'datavalid'),
                array('FailedLoginCount', 'safe'),

        );
    }else{
        return array(
                array('EmailAddress,EmailId, Password', 'required'),
                array('PersonId, ActiveFlag, FailedLoginCount', 'numerical', 'integerOnly'=>true),
                array('EmailAddress, Password', 'length', 'max'=>100),
                array('confirmPassword,', 'required','message' => Yii::t('message', 'PASSWORD_REQUIRED')),
                array('Password','length', 'max' => 100, 'min' => 6, 'tooShort' => Yii::t('message', 'PASSWORD_LENGTH')),
                array('confirmPassword', 'compare', 'compareAttribute'=>'Password','message' => Yii::t('message', 'PASSWORD_COMPARE')),
                array('chapterCode,', 'required','message' => Yii::t('message', 'CHAPTERCODE_REQUIRED')),
                array('verifyCode,', 'required','message' =>Yii::t('message', 'VERIFYCODE_REQUIRED')),
                array('verifyCode', 'captcha', 'allowEmpty'=>!CCaptcha::checkRequirements(),'caseSensitive'=>true,'message' =>Yii::t('message', 'VERIFYCODE_INCORRECT')),
                array('FailedLoginCount', 'safe'),
        );
    }
}

这里的
yt0
是注册页面上提交按钮的名称,因此对于注册,将应用
yt0
的规则,并且我有另一个更改密码的表单,因此在该页面上,我只需要三个字段,更改密码的提交按钮是
savecontact
,但是会应用savecontact规则,但是注册按钮规则冲突,因此注册时的验证无效。这是正确的方法来纠正上述规则吗?请提供任何建议。…

虽然这可能有效,但您的做法是错误的。 您应该使用
场景
来执行此类任务

首先,您可以为不同的表单声明场景:

class User extends ActiveRecord
{
    const SCENARIO_LOGIN = 'login';
    const SCENARIO_SIGNUP = 'signup';
    const SCENARIO_UPDATE = 'update';
}
定义场景后,您可以告诉您的模型使用哪些属性进行大规模分配,并对特定场景应用验证

class User extends ActiveRecord
{
    const SCENARIO_LOGIN = 'login';
    const SCENARIO_REGISTER = 'register';
    const SCENARIO_UPDATE = 'update';

    public function scenarios()
    {
        return [
            self::SCENARIO_LOGIN => ['username', 'password'],
            self::SCENARIO_REGISTER => ['email', 'username', 'password'],
            self::SCENARIO_UPDATE => ['email', 'username', 'password'],
        ];
    }
}
完成后,您可以选择添加验证规则或使用gii生成的默认规则

class User extends ActiveRecord
{
    const SCENARIO_LOGIN = 'login';
    const SCENARIO_REGISTER = 'register';
    const SCENARIO_UPDATE = 'update';

    public function scenarios()
    {
        return [
            self::SCENARIO_LOGIN => ['username', 'password'],
            self::SCENARIO_REGISTER => ['email', 'username', 'password'],
            self::SCENARIO_UPDATE => ['email', 'username', 'password'],
        ];
    }

    public function rules()
    {
        return ArrayHelper::merge([
            ['email' => 'email', 'message' => Yii::t('message', 'wrong email format')],
            [['email', 'password', 'username'] => 'email'],
            ['username', 'exist', 'on' => self::SCENARIO_LOGIN], // this will apply only on login
            // other rules
        ], parent::rules());
    }
}
现在您已经完成了模型场景和规则,是时候正确使用它们了

前往控制器并使用以下场景实例化模型:

public function actionLogin()
{
    $model = new User(['scenario' => User::SCENARIO_LOGIN]);

    if($model->load(Yii::$app->request->post())) {
        // $model will have username and password even if email is in the form since it is using
        // User::SCENARIO_LOGIN
        $model->validate(); 
        // will validate only username and password even if email is in the form
        // will also use the username exist validator
        // do your stuff
    }
}

public function actionRegister()
{
    $model = new User(['scenario' => User::SCENARIO_REGISTER]);

    if($model->load(Yii::$app->request->post())) {
        // $model will have username, password and email
        $model->validate(); 
        // will validate email, username and password but will not use the
        // username exist validation rule since it has the `'on' => self::SCENARIO_LOGIN`
        // do your stuff
    }
}

有关如何正确使用模型和验证的更多详细信息,请访问

感谢brother的回复,我会尝试一下,如果有任何疑问,我会询问