1

我有一个注册表单,允许用户在表单字段中输入他们的电子邮件或电话号码email_or_phone。我编写了一个验证函数,我在rules()函数中使用它来确保提交的值是有效的电子邮件或电话号码。然后将该值分配给afterValidation()函数中的正确模型属性。

email我的问题是,模型属性phone应该是唯一的。我编写了afterValidation()函数来测试相应表列的唯一性。但是代码不起作用。以下是我的afterValidation()功能:

protected function afterValidate(){
    parent::afterValidate();

    if(!$this->hasErrors() && $this->isNewRecord){

        $validator = new CEmailValidator;

        if($validator->validateValue($this->email_or_phone)){
            $validator = new CUniqueValidator;
            $validator->attributeName = 'email';
            $validator->validate($model, 'email_or_phone');
            if(!$this->hasErrors()) $this->email = $this->email_or_phone;
        }else{
            $validator = new CUniqueValidator;
            $validator->attributeName = 'phone';
            $validator->validate($model, 'email_or_phone');
            if(!$this->hasErrors()) $this->phone = $this->email_or_phone;
        }
    }
}

我究竟做错了什么?

4

1 回答 1

1

只需CUniqueValidator用于每个emailand phone,但配置'allowEmpty' = true.

还为电子邮件和电话字段定义设置器,您可以在其中检查它是电话还是电子邮件并将其设置或留空。

要获得唯一性错误消息,email_or_phone请添加来自两者的email消息phone。但要让它工作,需要一个小技巧。您必须将自己的验证规则定义为从 扩展的单独类CValidator,因此您可以从以下位置调用受保护的方法CUniqueValidator

class MyValidator extends CValidator
{
protected function validateAttribute($object, $attribute)
{
    // Some validation:
    if(!isPhoneOrEmail($object->$attribute))
    {
        $this->addError($attribute, 'This is not phone or email');
    }
    // Now check phone and email
    $validator = new CuniqueValidator();
    $validator->allowEmpty = true;
    $validator->validateAttribute($object, 'phone');
    // Now get errors for phone attribute
    $errors = $object->getErrors('phone');
    if($errors)
    {
        foreach($errors as $error)
        {
            $this->addError($attribute, $error);
        }
    }

    // Same for email
}
}
于 2013-05-16T06:57:52.697 回答