Yii2 验证规则

验证器的使用方法:

public function rules()
{
    return [
        [[‘email‘, ‘password‘], ‘required‘],
        [‘password‘, ‘string‘, ‘min‘=>6],
    ];
}

如上所示,验证器主要使用在rules里面,对当前model里面的属性值进行验证以检查是否满足某种要求。

验证器使用格式

书写格式为:[需要验证的属性,验证器名称,验证器参数]。

如果需要验证的属性为多个可用数组,如果为一个属性可用字符串也可用数组来表示。

每个属性都可以有多个验证器,如上面的password使用了 required和string两个验证器。

常用验证器

Yii2已经内置了一些常用的验证器。所有的验证器都从基类yii\validators\Validator继承实现。我大概总结下有这么几类。

数字相关

  • integer——整数

用来检测属性值是否为整数,以及最大、最小值检测等。(yii\validators\NumberValidator)

  • double——浮点

用来检测属性值是否为浮点数,即小数。(yii\validators\NumberValidator)

  • number——数字

这个和上面的double完全相同,只是用了2个名称。(yii\validators\NumberValidator)
格式相关

  • date——日期

检验属性值是否为正确的日期格式。(yii\validators\DateValidator)

  • email——邮件

检测属性值是否是正确的电子邮件格式。(yii\validators\EmailValidator)

  • url——URL

用来判断属性值是否是正确的url地址。(yii\validators\UrlValidator)
对值进行函数处理

  • filter——过滤器

这个是对属性值进行加工处理的。如对属性值加前缀、替换特定的字符串等等。(yii\validators\FilterValidator)

  • trim——裁边

这个是对属性值进行加工处理的。只是去掉字符串两侧的空格、或指定的字符串。(yii\validators\FilterValidator)
上传文件验证

  • file——文件

这个主要是对上传的文件进行验证,如格式、大小等。(yii\validators\FileValidator)

  • image——图片

这个和上面的file验证器差不多,不过是专门用来验证图片的。(yii\validators\ImageValidator)
判断比较

  • compare——比较

用来对两个属性值进行比较,如相等、大于、小于比较等。(yii\validators\CompareValidator)

  • in——包含(范围)

用来检测属性值是否包含在指定的数组中。(yii\validators\RangeValidator)

  • exist——存在

用来检测在数据表中是否已经存在此属性值。(yii\validators\ExistValidator)

  • unique——唯一性

这个和exist差不多,用来检测值是否是唯一。(yii\validators\UniqueValidator)

  • string——字符串

对属性值进行长度判断,如最大长度、最短长度等。(yii\validators\StringValidator)

  • boolean——布尔型

用来检查属性的值是否为布尔值。(yii\validators\BooleanValidator)

  • default——默认值

这个是用来给属性设置默认值的。如当属性值为null的时候,给它设置为 空的默认值。(yii\validators\DefaultValueValidator)

  • required——必填

这个用来检查属性值是否为空。(yii\validators\RequiredValidator)

  • captcha——验证码

这个主要是在界面使用验证码的时候对验证码进行验证的。(yii\captcha\CaptchaValidator)

  • match——正则表达式

这个就比较强大了,用来检测属性值是否匹配给出的正则。上面所列出的基本都可以用这个实现。(yii\validators\RegularExpressionValidator)
其它

  • safe——安全

这个不进行验证,仅仅用来指定属性值是安全的。(yii\validators\SafeValidator)
---------------------

源自博友的博客:https://blog.csdn.net/wjtlht928/article/details/46432413

原文地址:https://www.cnblogs.com/chrdai/p/9876833.html

时间: 2024-10-09 08:46:13

Yii2 验证规则的相关文章

yii2验证规则

1.内置验证规则 [['sex', 'partner_id'], 'integer'], [['partner_id', 'camp_id',], 'required'], [['created_at', 'pics'], 'safe'], [['name'], 'string', 'max' => 16], [['interest', 'quota'], 'number'], [['path'], 'unique'], ['username', 'unique', 'targetClass'

Yii2 rules验证规则

Rules验证规则:  required : 必须值验证属性||CRequiredValidator 的别名, 确保了特性不为空. [['字段名1','字段名2'],required]    //字段1 2 必填 [['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息'];  email : 邮箱验证||CEmailValidator 的别名,确保了特性的值是一个有效的电邮地址. ['email', 'email'];  match 

MVC中的验证规则

前面的博客中曾经提到过ModelBing机制,也在Demo中体现过,在MVC中更吊的是封装了自定义的验证规则.下面来一个Demo来展现一下,看了后,你一定会爱上它的,能让你少写很多JS语句. 1.View层 <span style="font-size:18px;">@*自动绑定实体模型*@ @model MvcApplication1.Models.User <h2>Login</h2> <form method="post&quo

Struts2 验证框架 validation.xml 常用的验证规则

Struts2 验证框架 validation.xml 常用的验证规则 validation.xml 的命名规则和放置路径:文件名:<ActionClassName>-validation.xml<ActionClassName>就是要验证的Action类的名字. 要将此文件放于Class文件相同的目录.如果在Action类在struts配置中有多个action实例(action name),那么对应某个action的验证文件名规则如下:文件名:<ActionClassNam

[Asp.net MVC]Asp.net MVC5系列——在模型中添加验证规则

目录 概述 在模型中添加验证规则 自定义验证规则 伙伴类的使用 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net MVC5系列——添加视图 [Asp.net MVC]Asp.net MVC5系列——添加模型 [Asp.net MVC]Asp.net MVC5系列——从控制器访问模型中的数据 [Asp.net MVC]Asp.net MVC5系列——添加数据 概述 上篇文章中介绍了添加数据,在提交表单的数据的时候,我们需

报错:非介入式客户端验证规则中的验证类型名称必须唯一。下列验证类型出现重复

当在ASP.NET MVC中,针对一个Model进行添加操作的时候,报如下错误: [InvalidOperationException: 非介入式客户端验证规则中的验证类型名称必须唯一.下列验证类型出现重复: range] 原因是第三方验证程序集和MVC固有验证发生名称的冲突. 解决办法:在Model中属性上注释掉第三方程序集提供的验证特性.

Yii CModel中rules验证规则

array( array(‘username’, ‘required’),  array(‘username’, ‘length’, ‘min’=>3, ‘max’=>12),  array(‘password’, ‘compare’, ‘compareAttribute’=>’password2′, ‘on’=>’register’),  array(‘password’, ‘authenticate’, ‘on’=>’login’), array(‘Price’,’num

JQuery validate验证规则

//定义中文消息 var cnmsg = { required: "必选字段", remote: "请修正该字段", email: "请输入正确格式的电子邮件", url: "请输入合法的网址", date: "请输入合法的日期", dateISO: "请输入合法的日期 (ISO).", number: "请输入合法的数字", digits: "只能输入整数

2016/05/15 ThinkPHP3.2.2 表单自动验证实例 验证规则的数组 直接写在相应的控制器里

使用TP 3.2框架 验证规则也可以写到模型里,但感觉有些麻烦, 一是有时候不同页面验证的方式会不一样, 二是看到这个   Add  事件里的代码,就清楚要接收什么数据,如何验证数据能够在第一眼有个大致了解 ①控制器代码页 1 <?php 2 namespace Home\Controller; 3 use Think\Controller; 4 5 header("Content-type: text/html; charset=utf-8"); 6 7 class AddCo