Yii2 rules验证规则

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, ‘账号或者密码错误!‘);
        }
    }
}
时间: 2024-10-18 17:29:55

Yii2 rules验证规则的相关文章

yii2 rules 验证规则

yii2  框架定义的约束 public $builtInValidators = [ 'boolean' => 'yii\validators\BooleanValidator', 'captcha' => 'yii\captcha\CaptchaValidator', 'compare' => 'yii\validators\CompareValidator', 'date' => 'yii\validators\DateValidator', 'default' =>

yii2 rules验证规则,ajax验证手机号码是否唯一

<?php namespace frontend\models; use Yii; use yii\base\Model; /** * Signup form */ class SignupForm extends Model { public $mobile; public $captcha; public $password; /** * @inheritdoc */ public function rules() { return [ [['mobile', 'captcha', 'pas

Yii CModel中rules验证规则

array( array(‘username’, ‘required’),  array(‘username’, ‘length’, ‘min’=>3, ‘max’=>12),  array(‘password’, ‘compare’, ‘compareAttribute’=>’password2′, ‘on’=>’register’),  array(‘password’, ‘authenticate’, ‘on’=>’login’), array(‘Price’,’num

Yii CModel中rules验证规则[转]

array( array(‘username’, ‘required’), array(‘username’, ‘length’, ‘min’=>3, ‘max’=>12), array(‘password’, ‘compare’, ‘compareAttribute’=>’password2′, ‘on’=>’register’), array(‘password’, ‘authenticate’, ‘on’=>’login’), array(‘Price’,’numeri

Yii2.0 rules验证规则大全

required : 必须值验证属性 [['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息']; #说明:CRequiredValidator 的别名, 确保了特性不为空. email : 邮箱验证 ['email', 'email']; #说明:CEmailValidator的别名,确保了特性的值是一个有效的电邮地址. match : 正则验证 [['字段名'],match,'pattern'=>'正则表达式','messa

[moka收藏]Yii2.0 rules验证规则

required : 必须值验证属性 [['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息']; #说明:CRequiredValidator 的别名, 确保了特性不为空. email : 邮箱验证 ['email', 'email']; #说明:CEmailValidator的别名,确保了特性的值是一个有效的电邮地址. match : 正则验证 [['字段名'],'match','pattern'=>'/正则表达式/','m

Yii 中比较常用的rules验证规则记录

查看代码 打印 01 return array( 02   03     //必须填写 04     array('email, username, password,agree,verifyPassword,verifyCode', 'required'), 05   06     //检查用户名是否重复 07     array('email','unique','message'=>'用户名已占用'), 08   09     //用户输入最大的字符限制 10     array('ema

yii2数据验证

1. 客户端验证 yii根据AR类rules()中的验证规则生成相应的Javascript验证代码.通过设置参数enableClientValidation的值来决定是否启用 客户端验证,默认为true,有以下3种方法来设置该参数的值. (1)在视图文件ActiveForm中对整个form进行设置: <?php $form = ActiveForm::begin([ 'enableClientValidation' =>true ]); ?> (2)在视图文件ActiveField中对单

yii rules 转自 安全者 &#187; Yii rules常用规则 ,适用Yii2

安全者 » Yii rules常用规则 ,适用Yii2 public function rules(){return array(//必须填写array('email, username, password,agree,verifyPassword,verifyCode', 'required'),//检查用户名是否重复array('email','unique','message'=>'用户名已占用'),//用户输入最大的字符限制array('email, username', 'length