yii验证规则,model中的rules验证的汇总

2024-05-03 13:38

本文主要是介绍yii验证规则,model中的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. filterCFilterValidator )-----过滤验证方法
实例array('name''test''message'=> '请填写姓名')
     public function test( $object $attributes ) {
          if ( $this ->name !=  '张先森' ) {
              $this ->addError( $object $attributes [ 'message' ]);
          }
     }
讲解
  • filte----方法名(调用用户自己定义的函数)
====================================================
3. matchCRegularExpressionValidator)-----正则验证属性
实例array('name''match''allowEmpty'=> 'true', 'not'=> 'true','pattern'=> '/[a-z]/i', 'message'=> '必须不是子母')
讲解
  • allowEmpty------boolean-----是否可以为空(默认为true)
  • not-------boolean------是否反转验证逻辑
  • pattern-------boolean------正则方法
====================================================
4. emailCEmailValidator)-----邮箱验证属性
实例array('name''email''allowEmpty'=> 'true','pattern'=> '/[a-z]/i', 'message'=> '必须不是子母')
讲解
  • allowEmpty------boolean-----是否可以为空(默认为true)
  • pattern-------boolean------正则方法
  • allowName-------boolean------是否允许在电子邮件地址的名称
  • checkMx-------boolean------是否检查电子邮件地址的MX记录
====================================================
5. urlCUrlValidator)-----url验证属性
实例array('name''url''allowEmpty'=> 'true','pattern'=> '/[a-z]/i', 'message'=> '必须不是子母')
讲解
  • allowEmpty------boolean-----是否可以为空(默认为true)
  • pattern-------boolean------正则方法
  • defaultScheme-------boolean------默认的URL方案
  • validSchemes-------boolean------清单应视为有效的URL计划
====================================================
6. uniqueCUniqueValidator)-----唯一性验证属性
实例array('name''unique''allowEmpty'=> 'true','caseSensitive'=> 'true', 'message'=> '必须不是子母')
讲解
  • allowEmpty-----------是否可以为空(默认为true)
  • caseSensitive-------------区分大小写
====================================================
7. compareCCompareValidator)-----比较验证属性
实例
    与某个值比: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. lengthCStringValidator )-----字符串验证属性
实例
    是否在某个范围内: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. inCRangeValidator )-----在某个范围内属性
实例
    必须在某个范围内: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. numericalCNumberValidator )-----数字验证属性
实例
    必须为整数: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. captchaCCaptchaValidator )-----验证码验证属性
实例 array ( 'name' 'captcha' 'caseSensitive' =>  'true''message'=> '验证码不正确' )
讲解
  • allowEmpty-----------是否可以为空(默认为true)
  • caseSensitive-------------区分大小写
====================================================
12. typeCTypeValidator )-----类型验证属性
实例 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. fileCFileValidator )-----文件验证属性
实例 array ( 'name' 'file' 'types' =>  array('jpg','gif','png'), 'message'=> '文件格式不正确' )
讲解
  • allowEmpty-----------是否可以为空(默认为true)
  • maxFiles-----------最大文件数
  • maxSize-----------文件最大值
  • minSize-----------文件最小值
  • tooLarge-----------文件太大的错误信息
  • tooMany-----------文件太多的错误信息
  • tooSmall-----------文件太小的错误信息
  • types-----------允许的扩展名
  • wrongType-----------扩展名错误时的错误信息
====================================================
14. defaultCDefaultValueValidator )-----默认值属性
实例 array ( 'name' 'default' ,  'setOnEmpty'=> 'true', 'value'=> '123' )
讲解
  • setOnEmpty-----------设置为空
  • value-----------默认值
====================================================
15. existCExistValidator )-----是否存在属性
讲解
  • allowEmpty-----------是否可以为空(默认为true)
  • attributeName-----------属性名称
  • className-----------类名
  • criteria-----------标准
====================================================
16. booleanCBooleanValidator )-----布尔类型验证属性
实例array('name''boolean', 'trueValue'=> '1', 'falseValue'=> '-1','message'=> '该值只能为1或-1' )
讲解
  • allowEmpty-----------是否可以为空(默认为true)
  • falseValue-----------错误状态的值
  • strict-----------严格验证
  • trueValue-----------真实状态的值

请大家尊重原创,本文也花费了不少心思,转发请写明出处
@让我们一起共同努力~

这篇关于yii验证规则,model中的rules验证的汇总的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/956882

相关文章

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

easyui同时验证账户格式和ajax是否存在

accountName: {validator: function (value, param) {if (!/^[a-zA-Z][a-zA-Z0-9_]{3,15}$/i.test(value)) {$.fn.validatebox.defaults.rules.accountName.message = '账户名称不合法(字母开头,允许4-16字节,允许字母数字下划线)';return fal

easyui 验证下拉菜单select

validatebox.js中添加以下方法: selectRequired: {validator: function (value) {if (value == "" || value.indexOf('请选择') >= 0 || value.indexOf('全部') >= 0) {return false;}else {return true;}},message: '该下拉框为必选项'}

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹

Adblock Plus官方规则Easylist China说明与反馈贴(2015.12.15)

-------------------------------特别说明--------------------------------------- 视频广告问题:因Adblock Plus的局限,存在以下现象,优酷、搜狐、17173黑屏并倒数;乐视、爱奇艺播放广告。因为这些视频网站的Flash播放器被植入了检测代码,而Adblock Plus无法修改播放器。 如需同时使用ads

MVC(Model-View-Controller)和MVVM(Model-View-ViewModel)

1、MVC MVC(Model-View-Controller) 是一种常用的架构模式,用于分离应用程序的逻辑、数据和展示。它通过三个核心组件(模型、视图和控制器)将应用程序的业务逻辑与用户界面隔离,促进代码的可维护性、可扩展性和模块化。在 MVC 模式中,各组件可以与多种设计模式结合使用,以增强灵活性和可维护性。以下是 MVC 各组件与常见设计模式的关系和作用: 1. Model(模型)