欢迎您的光临,本博所发布之文章皆为作者亲测通过,如有错误,欢迎通过各种方式指正。

文摘  Yii2常用验证规则,model中的rules验证的汇总

PHP框架 本站 1078 0评论

YII的models中的rules部分是一些表单的验证规则,对于表单验证十分有用,在相应的视图(views)里面添加了表单,在表单被提交之前程序都会自动先来这里面的规则里验证,只有通过对其有效的限制规则后才能被提交,可以很有效地保证表单安全和信息的有效性。而且也很节省校验代码的编写时间。 


下面来列举Yii提供给我们的简单的校验代码: 

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'=> '请填写姓名')

public function test($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'=> '必须不是子母')

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

讲解:

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)-----是否存在属性:

实例:

array('username','exist')

讲解:

allowEmpty-----------是否可以为空(默认为true)

attributeName-----------属性名称

className-----------类名

criteria-----------标准


16. boolean(CBooleanValidator)-----布尔类型验证属性:

实例:

array('name', 'boolean', 'trueValue'=> '1', 'falseValue'=> '-1','strict' => true,'message'=> '该值只能为1或-1')

讲解:

allowEmpty-----------是否可以为空(默认为true)

trueValue-----------真实状态的值

falseValue-----------错误状态的值

strict-----------严格验证


17.date(CDateValidator ) ----- 日期验证属性:

实例

array('username', 'date', 'format'=>'MM-dd-yyyy','message'=>'格式必须是 MM-dd-yyyy')

讲解:

allowEmpty -----------是否为空  

format -----------日期值应遵循的格式模式

timestampAttribute-----------接收解析结果的属性名称     


Yii2 rules常用验证规则


1.去除首尾空白字符

['email', 'trim']

['email', 'filter', 'filter' => 'trim']


2.字段必填

['email', 'required']


3.赋予默认值

['age', 'default', 'value' => 18]


4.字符串长度

['email', 'string', 'min' => 3, 'max' => 20]

['email', 'string', 'length' => [3, 20]]


5.格式类型验证

['age', 'integer'] // 整数格式

['salary', 'double']// 浮点数格式

['temperature', 'number']// 数字格式

['isAdmin', 'boolean']// 布尔格式

['email', 'email']// email格式

['birthday', 'date']// 日期格式

['website', 'url', 'defaultScheme' => 'http']// URL格式


6.验证码

['verificationCode', 'captcha']


7.值在数据表中是唯一的

['email', 'unique', 'targetClass' => '\common\models\Users']


8.值在数据表中已存在

['email', 'exist',

'targetClass' => '\common\models\User',

'filter' => ['status' => User::STATUS_ACTIVE],

'message' => 'There is no user with such email.'],


9.检查输入的两个值是否一致

['passwordRepeat', 'required'] // 必须要加上这一句

['passwordRepeat', 'compare', 'compareAttribute' => 'password', 'operator' => '===']


10.数值范围检查

['age', 'compare', 'compareValue' => 30, 'operator' => '>=']   //比较

['level', 'in', 'range' => [1, 2, 3]]   //在一定的范围内


11.使用自定义函数过滤

['email', 'filter', 'filter' => function($value) {

// 在此处标准化输入的email

return strtolower($value);

}]

['email','myselfFun']

public function myselfFun($data){
if($data){ 
...
return true;
}else{
...
return false;
}
}


12.文件上传

['textFile', 'file', 'extensions' => ['txt', 'rtf', 'doc'], 'maxSize' => 1024 * 1024 * 1024]


13.图片上传

['avatar', 'image', 'extensions' => ['png', 'jpg'],

'minWidth' => 100, 'maxWidth' => 1000,

'minHeight' => 100, 'maxHeight' => 1000,

]


14.使用正则表达式

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

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

['username', 'match', 'pattern' => '/^[a-z]\w*$/i']


15.safe : 安全

['description', 'safe'];


参考网址:

https://www.yiichina.com/tutorial/635 


原文地址:https://blog.csdn.net/u010010725/article/details/51099326

转载请注明: ITTXX.CN--分享互联网 » Yii2常用验证规则,model中的rules验证的汇总

最后更新:2021-07-16 11:32:15

赞 (1) or 分享 ()
游客 发表我的评论   换个身份
取消评论

表情
(0)个小伙伴在吐槽