yii rules常用规则

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

     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-----------真实状态的值

原文地址:https://blog.csdn.net/xiaoxinshuaiga/article/details/88390662

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


1、将Yii2.0advanced版中应用主体frontend或backend应用复制为api应用2、在应用主体api目录的controller新建SiteController.php:namespaceapi\controllers;useYii;useyii\rest\ActiveController;/*SiteController测试控制器*/classSiteControllerextendsActiveCon
Yii2restfulAPI文档一、配置模块:1.Config/main.php:  2.创建模块目录:  3.Module.php:  二、路由配置:  三、控制器:  四、Models:   五、测试:GET:  POST:  PUT:      DELETE:  
Yii在framework/i18n/data/%lang%.php文件中有很多翻译.这是例如germantranslations我想在我的Yii项目中使用Fullcalendar.要翻译此日历,我必须为当前语言提供一个monthNames/dayNames数组.FullcalendarmonthNamesDocumentationYii生成数组的最佳方法是什么:['January'
在Yii2中,官方的页面多语言解决方案有两个:方案1,使用Yii::t()函数,在页面中需要输出文字的地方,使用类似如下代码:<?=Yii::t(‘views/login’,‘hello’)?>这样做的后果是页面上大量充斥着类似的代码,导致页面可读性很差,而且对于同一个页面来说,Yii::t()函数的第一个参数基本上都是
Yii2.0对数据库查询的一些简单的操作123456789101112131415161718192021222324252627282930313233343536373839User::findOne($id);   //此方法返回 主键 id=1  的一条数据(举个例子);  User::find()->where(['name' =
数据查询User::find()->all();此方法返回所有数据;User::findOne($id);此方法返回主键id=1的一条数据(举个例子);User::find()->where(['name'=>'小伙儿'])->one();此方法返回['name'=>'小伙儿']的一条数据;User::find()->where(['n
最近打算提升自己的解决问题能力,于是打算从学习其他框架下手,让我们先去了解yii框架是如何运作的吧!https://www.yiichina.com/访问yii中文网站  让我们先把框架下载下来点击下载框架 科普一下:目前yii框架有三个版本yii1.0、yii1.1、yii2.0貌似即将推出3.0 这里我们
如何在Yii2中检查模型属性的类型(列类型)?ThisoldYiiForumanswer给了我一个结论,在Yii1中我可以使用类似的东西:$model->getMetaData()->columns['attribute-name']->type;但我没有成功将此解决方案移植到Yii2.有人可以帮忙吗?解决方法:您可以使用:$model->getTableSchema()
defined('YII_DEBUG')ordefine('YII_DEBUG',true);defined('YII_ENV')ordefine('YII_ENV','dev');require(__DIR__.'/../vendor/autoload.php');//注册类加载器require(__DIR__.'/../vendor/yii
在NGINX中配置:location/{   if(!-e$request_filename){    rewrite^/(.*)/index.phplast;}这样,当NGINX找不到文件的时候,就会将URL重写为index.php。对于URL中只有域名的情况,因为不存在对应的文件,所以会匹配到。再配置:location~\.php${  include
Yii2.0封装的类足够强大,Mailer的使用方法做一个总结:1、先在main-local.php中做好配置:return[//....'components'=>['mailer'=>['class'=>'yii\swiftmailer\Mailer',],],];详细如下:return[//....'components'=>[
每当我尝试登录我的Yii应用程序时,它都会显示错误CDbConnectionfailedtoopentheDBconnection:couldnotfinddriver.我google了很多个小时,从许多博客我知道我需要pdo_mysql,但已经安装了.在php.ini中我也对这些行做了评论;extension=php_pdo_mysql.dll;extension
我有一个模型Aziende,它与称为Annunci的花药模型相关(1:N),如下所示:'annunci'=>array(self::HAS_MANY,'Annunci','azienda_id'),我想算一下有多少记录确实有这种关系,在mySql中我会做:SELECTcount(*)FROM`aziende`aJOINannuncianONan.azienda_id=a.id我怎么能
我们有一个项目,为孟加拉国最大的服装行业之一建立一个ERP系统.他们有大约20,000名员工,其中约10%的员工每个月都会离职.我们是一家拥有5名PHP开发人员的小公司,对这么大的项目没有多少经验.我们之前使用Codeigniter/ZendFramework和MySQL数据库开发了不同的中小规模项目.对于
我在Yii中有一些表单,使用以下内容以下拉形式从相关表中获取数据列表:dropDownList(CHtml::listData(Company::model()->findAll(array('order'=>'companyASC'))));这是有效的,但这意味着对于每个下拉列表(其中很多)我将这个数组(‘order’=>’公司ASC’放在每一个中.这是最
本文采用Yii文档,经过自己的修改,让读者更容易理解预定义完整列表: boolean : CBooleanValidator 的别名,确保属性的值是CBooleanValidator::trueValue 或CBooleanValidator::falseValue .captcha : CCaptchaValidator 的别名,确保了特性的值等于 CAPTCHA 显示出来
前面已经安装好了yii框架,现在我们来建立第一个Yii应用1、进入您网站更目录2、执行命令:YiiRoot/framework/yiicwebapptestdrive说明:这里的YiiRoot为您Yii框架的安装目录。3、输入以上命令后,会出现一个提示信息:PHPWarning:PHPStartup:Unabletol
一、ThinkPHPThinkPHP(FCS)是一个轻量级的中型框架,是从Java的Struts结构移植过来的中文PHP开发框架。它使用面向对象的开发结构和MVC模式,并且模拟实现了Struts的标签库,各方面都比较人性化,熟悉J2EE的开发人员相对比较容易上手,适合php框架初学者。ThinkPHP的宗旨是简化开发、提
我必须实现标题中提到的验证,即需要两个字段之一(电子邮件,电话).我在我的模型中这样做:[['email'],'either',['other'=>['phone']]],这是方法:publicfunctioneither($attribute_name,$params){$field1=$this->getAttributeLabel($attribute_nam
我试图得到(StatusCode)响应RESTapi,而它只返回字段名称和错误消息,如下所示[{"field":"Email","message":"Email\"ali@ali.ali\"hasalreadybeentaken."}]我添加了回复'response'=>['class'=>'