Yii2 rules验证规则

6 篇文章 0 订阅

required : 必须值验证属性

[['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息']; #说明:CRequiredValidator 的别名, 确保了特性不为空. 

email : 邮箱验证

['email', 'email']; #说明:CEmailValidator的别名,确保了特性的值是一个有效的电邮地址. 

match : 正则验证

[['字段名'],match,'pattern'=>'正则表达式','message'=>'提示信息'];      

[['字段名'],match,'not'=>ture,'pattern'=>'正则表达式','message'=>'提示信息']; /*正则取反*/ #说明:CRegularExpressionValidator 的别名, 确保了特性匹配一个正则表达式. 

url : 网址

['website', 'url', 'defaultScheme' => 'http']; #说明:CUrlValidator 的别名, 确保了特性是一个有效的路径. 

captcha : 验证码

['verificationCode', 'captcha']; #说明:CCaptchaValidator 的别名,确保了特性的值等于 CAPTCHA 显示出来的验证码. 

safe : 安全

['description', 'safe'];

compare : 比较

['age', 'compare', 'compareValue' => 30, 'operator' => '>=']; #说明:compareValue(比较常量值) - operator(比较操作符)  #说明:CCompareValidator 的别名,确保了特性的值等于另一个特性或常量. 

default : 默认值

['age', 'default', 'value' => null]; #说明:CDefaultValueValidator 的别名, 为特性指派了一个默认值. 

exist : 存在

['username', 'exist']; #说明:CExistValidator 的别名,确保属性值存在于指定的数据表字段中. 

file : 文件

['primaryImage', 'file', 'extensions' => ['png', 'jpg', 'gif'], 'maxSize' => 1024*1024*1024]; #说明:CFileValidator 的别名, 确保了特性包含了一个上传文件的名称. 

filter : 滤镜

[['username', 'email'], 'filter', 'filter' => 'trim', 'skipOnArray' => true]; #说明:CFilterValidator 的别名, 使用一个filter转换属性. 

in : 范围

['level', 'in', 'range' => [1, 2, 3]]; #说明:CRangeValidator 的别名,确保了特性出现在一个预订的值列表里. 

unique : 唯一性

['username', 'unique'] #说明:CUniqueValidator 的别名,确保了特性在数据表字段中是唯一的. 

integer : 整数

['age', 'integer'];

number : 数字

['salary', 'number'];

double : 双精度浮点型

['salary', 'double'];

date : 日期

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

string : 字符串

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

boolean : 是否为一个布尔值

['字段名', 'boolean', 'trueValue' => true, 'falseValue' => false, 'strict' => true]; #说明:CBooleanValidator 的别名 

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

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


去除首尾空白字符

[php]  view plain  copy
  1. ['email''trim'] 或 ['email''filter''filter' => 'trim']  

字段必填

[php]  view plain  copy
  1. ['email''required']  

赋予默认值

[php]  view plain  copy
  1. ['age''default''value' => 20]  

字符串长度

[php]  view plain  copy
  1. ['email''string''min' => 3, 'max' => 20] 或 ['email''string''length' => [3, 20]]  

格式类型验证

[php]  view plain  copy
  1. ['age''integer'// 整数格式  
  2. ['salary''double'// 浮点数格式  
  3. ['temperature''number'// 数字格式  
  4. ['isAdmin''boolean'// 布尔格式  
  5. ['email''email'// email格式  
  6. ['birthday''date'// 日期格式  
  7. ['website''url''defaultScheme' => 'http'// URL格式  


验证码

[php]  view plain  copy
  1. ['verificationCode''captcha']  


值在数据表中是唯一的

[php]  view plain  copy
  1. ['email''unique''targetClass' => 'commonmodelsUsers']  


值在数据表中已存在

[php]  view plain  copy
  1. ['email''exist',     'targetClass' => 'commonmodelsUser',     'filter' => ['status' => User::STATUS_ACTIVE],     'message' => 'There is no user with such email.']  

检查输入的两个值是否一致
[php]  view plain  copy
  1. ['passwordRepeat''required'// 必须要加上这一句 ['passwordRepeat', 'compare', 'compareAttribute' => 'password', 'operator' => '===']  

数值范围检查
[php]  view plain  copy
  1. ['age''compare''compareValue' => 30, 'operator' => '>=']  
  2. ['level''in''range' => [1, 2, 3]]  

使用自定义函数过滤
[php]  view plain  copy
  1. ['email''filter''filter' => function($value) {     // 在此处标准化输入的email     return strtolower($value); }]  

文件上传
[php]  view plain  copy
  1. ['textFile''file''extensions' => ['txt''rtf''doc'], 'maxSize' => 1024 * 1024 * 1024]  

图片上传
[php]  view plain  copy
  1. ['avatar''image''extensions' => ['png''jpg'],     'minWidth' => 100, 'maxWidth' => 1000,     'minHeight' => 100, 'maxHeight' => 1000, ]  

使用正则表达式
[php]  view plain  copy
  1. ['username''match''pattern' => '/^[a-z]w*$/i']  

这个要写一个方法验证,比如/** 
* 校验手机号码 
*/ 
public function checkMobile(){ 
$reg = '/^1[3|5|8]\d{9}$/'; 
if($this->mobile && !preg_match($reg, $this->mobile)){ 
$this->addError('mobile', Yii::t('common','Mobile Is Invalid')); 
return false; 


然后在rules里面调用array('mobile','checkMobile', 'on'=>'update'), 
判断方法里面加上或条件就可以了,这只是一个例子说明


yii\base\Model::rules() 方法应返回一个由规则所组成的数组,每一个规则都呈现为以下这类格式的小数组:

[
    // 必须项,用于指定那些模型特性需要通过此规则的验证。
    // 对于只有一个特性的情况,可以直接写特性名,而不必用数组包裹。
    ['attribute1', 'attribute2', ...],

    // 必填项,用于指定规则的类型。
    // 它可以是类名,验证器昵称,或者是验证方法的名称。
    'validator',

    // 可选项,用于指定在场景(scenario)中,需要启用该规则
    // 若不提供,则代表该规则适用于所有场景
    // 若你需要提供除了某些特定场景以外的所有其他场景,你也可以配置 "except" 选项
    'on' => ['scenario1', 'scenario2', ...],

    // 可选项,用于指定对该验证器对象的其他配置选项
    'property1' => 'value1', 'property2' => 'value2', ...
]

对于每个规则,你至少需要指定该规则适用于哪些特性,以及本规则的类型是什么。你可以指定以下的规则类型之一:

核心验证器的昵称,比如 required、in、date,等等。请参考核心验证器章节查看完整的核心验证器列表。
模型类中的某个验证方法的名称,或者一个匿名方法。请参考行内验证器小节了解更多。
验证器类的名称。请参考独立验证器小节了解更多。
一个规则可用于验证一个或多个模型特性,且一个特性可以被一个或多个规则所验证。一个规则可以施用于特定场景(scenario),只要指定 on 选项。如果你不指定 on 选项,那么该规则会适配于所有场景。

当调用 validate() 方法时,它将运行以下几个具体的验证步骤:

检查从声明自 yii\base\Model::scenarios() 方法的场景中所挑选出的当前yii\base\Model::scenario的信息,从而确定出那些特性需要被验证。这些特性被称为激活特性。
检查从声明自 yii\base\Model::rules() 方法的众多规则中所挑选出的适用于当前yii\base\Model::scenario的规则,从而确定出需要验证哪些规则。这些规则被称为激活规则。
用每个激活规则去验证每个与之关联的激活特性。
基于以上验证步骤,有且仅有声明在 scenarios() 方法里的激活特性,且它还必须与一或多个声明自 rules() 里的激活规则相关联才会被验证。




提示:打印出 Validator::$builtInValidators 可以看到被支持的所有validators
[php]  view plain  copy
  1. Array  
  2. (  
  3.     [boolean] => yii\validators\BooleanValidator  
  4.     [captcha] => yii\captcha\CaptchaValidator  
  5.     [compare] => yii\validators\CompareValidator  
  6.     [date] => yii\validators\DateValidator  
  7.     [default] => yii\validators\DefaultValueValidator  
  8.     [double] => yii\validators\NumberValidator  
  9.     [each] => yii\validators\EachValidator  
  10.     [email] => yii\validators\EmailValidator  
  11.     [exist] => yii\validators\ExistValidator  
  12.     [file] => yii\validators\FileValidator  
  13.     [filter] => yii\validators\FilterValidator  
  14.     [image] => yii\validators\ImageValidator  
  15.     [in] => yii\validators\RangeValidator  
  16.     [integer] => Array  
  17.         (  
  18.             [class] => yii\validators\NumberValidator  
  19.             [integerOnly] => 1  
  20.         )  
  21.   
  22.     [match] => yii\validators\RegularExpressionValidator  
  23.     [number] => yii\validators\NumberValidator  
  24.     [required] => yii\validators\RequiredValidator  
  25.     [safe] => yii\validators\SafeValidator  
  26.     [string] => yii\validators\StringValidator  
  27.     [trim] => Array  
  28.         (  
  29.             [class] => yii\validators\FilterValidator  
  30.             [filter] => trim  
  31.             [skipOnArray] => 1  
  32.         )  
  33.   
  34.     [unique] => yii\validators\UniqueValidator  
  35.     [url] => yii\validators\UrlValidator  
  36.     [ip] => yii\validators\IpValidator  
  37. )  



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值