Yii2.0 rules验证规则大全

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,]

 

详解》》》》》》

  • boolean : CBooleanValidator 的别名, 确保属性的值是CBooleanValidator::trueValue 或CBooleanValidator::falseValue .
  • captcha : CCaptchaValidator 的别名,确保了特性的值等于 CAPTCHA 显示出来的验证码.
  • compare : CCompareValidator 的别名, 确保了特性的值等于另一个特性或常量.
  • email : CEmailValidator 的别名,确保了特性的值是一个有效的电邮地址.
  • default : CDefaultValueValidator 的别名, 为特性指派了一个默认值.
  • exist : CExistValidator 的别名, 确保属性值存在于指定的数据表字段中.
  • file : CFileValidator 的别名, 确保了特性包含了一个上传文件的名称.
  • filter : CFilterValidator 的别名, 使用一个filter转换属性.
  • in : CRangeValidator 的别名, 确保了特性出现在一个预订的值列表里.
  • length : CStringValidator 的别名, 确保了特性的长度在指定的范围内.
  • match : CRegularExpressionValidator 的别名, 确保了特性匹配一个正则表达式.
  • numerical : CNumberValidator 的别名, 确保了特性是一个有效的数字.
  • required : CRequiredValidator 的别名, 确保了特性不为空.
  • type : CTypeValidator 的别名, 确保了特性为指定的数据类型.
  • unique : CUniqueValidator 的别名, 确保了特性在数据表字段中是唯一的.
  • url : CUrlValidator 的别名, 确保了特性是一个有效的路径 
 
注:下列数组中第一个值和第二个值为必填项,message的值为错误提示信息
====================================================

1. reqiurd(CRequiredValidator)-----必须验证属性:

实例:array('name''required''requiredValue'=> '张', 'strict'=> true, 'message'=> '请填写姓名')
  • requiredValue------mixed-----所需的值
  • strict-------boolean------是否比较严格
====================================================
2. filter(CFilterValidator )-----过滤验证方法:
实例:array('name''test''message'=> '请填写姓名')
     publicfunctiontest($object$attributes) {
         if($this->name != '张先森') {
             $this->addError($object$attributes['message']);
         }
     }
讲解:
  • filte----方法名(调用用户自己定义的函数)
====================================================
3. match(CRegularExpressionValidator)-----正则验证属性:
实例:array('name''match''allowEmpty'=> 'true', 'not'=> 'true','pattern'=> '/[a-z]/i', 'message'=> '必须不是子母')
讲解:
  • allowEmpty------boolean-----是否可以为空(默认为true)
  • not-------boolean------是否反转验证逻辑
  • pattern-------boolean------正则方法
====================================================
4. email(CEmailValidator)-----邮箱验证属性:
实例:array('name''email''allowEmpty'=> 'true','pattern'=> '/[a-z]/i', 'message'=> '必须不是子母')
讲解:
  • allowEmpty------boolean-----是否可以为空(默认为true)
  • pattern-------boolean------正则方法
  • allowName-------boolean------是否允许在电子邮件地址的名称
  • checkMx-------boolean------是否检查电子邮件地址的MX记录
====================================================
5. url(CUrlValidator)-----url验证属性:
实例:array('name''url''allowEmpty'=> 'true','pattern'=> '/[a-z]/i', 'message'=> '必须不是子母')
讲解:
  • allowEmpty------boolean-----是否可以为空(默认为true)
  • pattern-------boolean------正则方法
  • defaultScheme-------boolean------默认的URL方案
  • validSchemes-------boolean------清单应视为有效的URL计划
====================================================
6. unique(CUniqueValidator)-----唯一性验证属性:
实例:array('name''unique''allowEmpty'=> 'true','caseSensitive'=> 'true', 'message'=> '必须不是子母')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • caseSensitive-------------区分大小写
====================================================
7. compare(CCompareValidator)-----比较验证属性:
实例:
    与某个值比:array('name''compare''allowEmpty'=> 'true','compareValue'=> '10','operator'=> '>', 'message'=> '必须大于10')
    与某个提交的属性比:array('name''compare''allowEmpty'=> 'true','compareAttribute'=> 'password','operator'=> '>', 'message'=> '必须大于password')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • compareAttribute-------------需要比较的属性
  • compareValue-------------需要比较的值
  • operator-------------比较运算符
  • strict-------------严格执行(值和类型都要相等)
====================================================
8. length(CStringValidator)-----字符串验证属性:
实例:
    是否在某个范围内:array('name''length''allowEmpty'=> 'true','max'=> '10','min'=> '5', 'tooLong'=> '太长了','tooShort'=> '太短了')
    必须是某个长度:array('name''length''is'=> '5', 'message'=> '长度必须为5')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • encoding-------------编码
  • is-------------确切的长度
  • max-------------最大长度
  • min-------------最小长度
  • tooLong-------------定义值太大的错误
  • tooShort-------------定义值太大的错误
====================================================
9. in(CRangeValidator)-----在某个范围内属性:
实例:
    必须在某个范围内:array('name''in''range'=> array(1,2,3,4,5),'message'=> '值必须为1,2,3,4,5')
    不能在某个范围内array('name''in','not'=> 'true', 'range'=> array(1,2,3,4,5),'message'=> '值不能为1,2,3,4,5')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • not-------------是否反转的验证逻辑
  • range-------------array范围
  • strict-------------严格执行(值和类型都要相等)
====================================================
10. numerical(CNumberValidator)-----数字验证属性:
实例:
    必须为整数:array('name''numerical''integerOnly'=> 'true''message'=> '值必须为整数')
    值必须在一个范围内array('name''numerical''integerOnly'=> 'true''message'=> '值必须为整数', 'max'=> '100', 'min'=> '10','tooBig'=> '值太大了','tooSmall'=> '值太小了')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • integerOnly-------------整数
  • integerPattern-------------正则表达式匹配整数
  • max-------------最大值
  • min-------------最小值
  • numberPattern-------------匹配号码
  • tooBig-------------值太大时的提示
  • tooSmall-------------值太小时的提示
====================================================
11. captcha(CCaptchaValidator)-----验证码验证属性:
实例:array('name''captcha''caseSensitive'=> 'true''message'=> '验证码不正确')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • caseSensitive-------------区分大小写
====================================================
12. type(CTypeValidator)-----类型验证属性:
实例:array('name''type''dateFormat'=> 'MM/dd/yyyy''type'=> 'date''message'=> '类型不正确')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • dateFormat-------------日期应遵循的格式模式('MM/dd/yyyy')
  • datetimeFormat-------------日期时间应遵循的格式模式('MM/dd/yyyy hh:mm')
  • timeFormat-------------时间应遵循的格式模式('hh:mm')
  • type-------------类型 ‘string’, ‘integer’, ‘float’, ‘array’, ‘date’, ‘time’, ‘datetime’
====================================================
13. file(CFileValidator)-----文件验证属性:
实例:array('name''file''types'=> array('jpg','gif','png'), 'message'=> '文件格式不正确')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • maxFiles-----------最大文件数
  • maxSize-----------文件最大值
  • minSize-----------文件最小值
  • tooLarge-----------文件太大的错误信息
  • tooMany-----------文件太多的错误信息
  • tooSmall-----------文件太小的错误信息
  • types-----------允许的扩展名
  • wrongType-----------扩展名错误时的错误信息
====================================================
14. default(CDefaultValueValidator)-----默认值属性:
实例:array('name''default', 'setOnEmpty'=> 'true', 'value'=> '123')
讲解:
  • setOnEmpty-----------设置为空
  • value-----------默认值
====================================================
15. exist(CExistValidator)-----是否存在属性:
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • attributeName-----------属性名称
  • className-----------类名
  • criteria-----------标准
====================================================
16. boolean(CBooleanValidator)-----布尔类型验证属性:
实例:array('name''boolean', 'trueValue'=> '1', 'falseValue'=> '-1','message'=> '该值只能为1或-1')
讲解:
  • allowEmpty-----------是否可以为空(默认为true)
  • falseValue-----------错误状态的值
  • strict-----------严格验证
  • trueValue-----------真实状态的值
 

有漏的大家可以留言补充。互相学习

 

 

《php基础语法课程》

posted @ 2018-09-01 15:53  温情亿度开发者  阅读(1012)  评论(0编辑  收藏  举报