yii2.0-rules验证规则应用实例

文章 · 本文由 · 上班偷偷打酱油 · 发布于 3年前 · 2467 阅读

Rules验证规则:

 required : 必须值验证属性||CRequiredValidator 的别名, 确保了特性不为空.

[['字段名1','字段名2'],required]    //字段1 2 必填

[['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息'];

 email : 邮箱验证||CEmailValidator 的别名,确保了特性的值是一个有效的电邮地址.

['email', 'email'];

 match : 正则验证||CRegularExpressionValidator 的别名, 确保了特性匹配一个正则表达式.

[['字段名'],'match','pattern'=>'正则表达式','message'=>'提示信息'];      
[['字段名'],'match','not'=>ture,'pattern'=>'正则表达式','message'=>'提示信息'];  /*正则取反*/

 url : 网址||CUrlValidator 的别名, 确保了特性是一个有效的路径.

['website', 'url', 'defaultScheme' => 'http'];

captcha(验证码)||CCaptchaValidator 的别名,确保了特性的值等于 CAPTCHA 显示出来的验证码.

['verificationCode', 'captcha'];

safe : 安全

['description', 'safe'];

compare :(比较) CCompareValidator 的别名, 确保了特性的值等于另一个特性或常量.

['repassword', 'compare', 'compareAttribute' => 'password','message'=>'两次输入的密码不一致!'],

//compareValue:比较常量值 operator:比较操作符 
['age', 'compare', 'compareValue' => 30, 'operator' => '>='];

 default : 默认值||CDefaultValueValidator 的别名, 为特性指派了一个默认值.

['age', 'default', 'value' => null];

 exist : 存在||CExistValidator 的别名, 确保属性值存在于指定的数据表字段中.

['字段名', 'exist'];

 file : 文件||CFileValidator 的别名, 确保了特性包含了一个上传文件的名称.

['primaryImage', 'file', 'extensions' => ['png', 'jpg', 'gif'], 'maxSize' => 1024*1024*1024]

 filter : 滤镜||CFilterValidator 的别名, 使用一个filter转换属性.

//'skipOnArray' => true 非必填
[['username', 'email'], 'filter', 'filter' => 'trim', 'skipOnArray' => true];

 in : 范围||CRangeValidator 的别名, 确保了特性出现在一个预订的值列表里.

['level', 'in', 'range' => [1, 2, 3]];

 unique : 唯一性||CUniqueValidator 的别名, 确保了特性在数据表字段中是唯一的.

['字段名', 'unique']

 补充:联合唯一索引rule规则

[
    ['app_id', 'group_id'], 
    'unique', 
    'targetAttribute' => ['app_id', 'group_id'], 
    'message' => 'app_id和group_id已经被占用!'
],

 integer : 整数

['age', 'integer'];

 number : 数字

['salary', 'number'];

 double : 双精度浮点型

['salary', 'double'];

 date : (日期)

[['from', 'to'], 'date'];

 string : 字符串

['username', 'string', 'length' => [4, 24]];

 boolean : 是否为一个布尔值||CBooleanValidator 的别名

['字段名', 'boolean', 'trueValue' => true, 'falseValue' => false, 'strict' => true];

 image :是否为有效的图片文件

[
    'primaryImage', 
    'image', 
    'extensions' => 'png, jpg',  
    'minWidth' => 100, 'maxWidth' => 1000,  'minHeight' => 100, 'maxHeight' => 1000
]

 each:遍历,ids 和 product_ids 是数字的集合

[['ids', 'product_ids'], 'each', 'rule' => ['integer']],


自定义rules:

['password', 'validatePassword'],

/**
 * Validates the password.
 * This method serves as the inline validation for password.
 *
 * @param string $attribute the attribute currently being validated
 * @param array $params the additional name-value pairs given in the rule
 */
public function validatePassword($attribute, $params)
{
    if (!$this->hasErrors()) {
        $user = $this->getUser();
        if (!$user || !$user->validatePassword($this->password)) {
            $this->addError($attribute, '账号或者密码错误!');
        }
    }
}