核心验证器 Core Validators
前言
Yii 提供了一系列常用的核心 validators, 你可在
yii\validators namespace 中找到. 不用使用长的验证器类名, 你可以使用别名代替他们.
例如, 你可以使用别名 required 代替 yii\validators\RequiredValidator 类:
<?php public function rules() { return [ [['email', 'password'], 'required'], ]; } ?>
这个 yii\validators\Validator::$builtInValidators 属性生命所有支持的验证器的别名.
接下来, 我们将讲解每种核心验证器的用法.
1. boolean 对错值
<?php [ // 检查是否 "selected" 是 0 或 1, 不管数据类型 ['selected', 'boolean'], // 检查是否 "deleted" 是一个 boolean 类型, 只能是 true 或则 false ['deleted', 'boolean', 'trueValue' => true, 'falseValue' => false, 'strict' => true], ] ?>
上面检测是否是一个bool值.
trueValue: 代表true时的值. 默认为 '1'.
falseValue: 代表 false 时的值. 默认为 '0'.
strict: 是否输入框中的值必须匹配 设置的 trueValue 和 falseValue. 默认为 false.
注意: 因为数据提交通过HTML形式都是字符创, 一般你需要设置 strict 属性为 false.
2. captcha 验证码
<?php [ ['verificationCode', 'captcha'], ] ?>
这个验证器通常和
yii\captcha\CaptchaAction 以及
yii\captcha\Captcha 一起使用以确保输入的是相同的验证码 通过 CAPTCHA 组件.
caseSensitive: 是否验证码需要区分大小写. 默认为 false.
captchaAction: 默认的验证码的 CAPTCHA action 生成 CAPTCHA image的路径. 默认为 'site/captcha'.
skipOnEmpty: 输入为空的时候是否跳过验证. 默认false, 即 input 输入是必须的.
3. compare 比较
<?php [ // 验证是否 "password" 属性和 "password_repeat"是否相等 ['password', 'compare'], // 验证 age >= 30 ['age', 'compare', 'compareValue' => 30, 'operator' => '>='], ] ?>
这个验证器比较指定的输入值和另一个值确保他们之间使用指定的操作符.
compareAttribute: 属性的名字即将会和谁比较.当验证器被用来验证一个属性的时候, 他会和属性名字相同 但带有后缀 _repeat的属性相比较. 例如, 如果要验证的属性名是 password, 那么默认对比的属性名就是 password_repeat 你可以指定你想要的值.
compareValue: 一个和输入值比较的常量值. 当 property 和 compareAttribute 属性被同时指定的时候, 这个值将优先.
operator: 比较的操作符. 默认是 ==, 即输入值和 compareAttribute 或 compareValue 值相等的时候才会成功.
支持下面这些操作符: ==、===、!=、!==、>、>=、<、<=。
4. date 日期
<?php [ [['from_date', 'to_date'], 'date'], ] ?>
这个验证器检查输入的值是一个日期date, 时间time 或者datetime 以一个合适的形式. 可选的,他能转换输入值成为一个UNIX时间戳存储在一个通过timestampAttribute 指定的属性里.
format: 这个 date/time 是 中声明的所有支持的格式
如果这个值没有设置, 他会自动取值 Yii::$app->formatter->dateFormat.
timestampAttribute: 属性名用来存储转换将输入的日期或时间. 也可以是相同的属性名作为被验证过的. 如果是这种情况, 原始的值将会被时间戳重写. 你可以看看 "如何处理日期选择器 DatePicker" 用例子.
如果输入的是可选的,你也可能要添加一个默认值滤波器除了日期验证,以确保空输入存储为NULL。否则你可能最终得到的日期像日期选择器的输入字段在0000-00-00 或 您的数据库1970-01-01.
<?php [ [['from_date', 'to_date'], 'default', 'value' => null], [['from_date', 'to_date'], 'date'], ], ?>
5.default 默认值
<?php [ // 设置 "age" 为 null 如果他是空的 ['age', 'default', 'value' => null], // 设置 "country" 为 "USA" 如果他是空的 ['country', 'default', 'value' => 'USA'], // 分配 "from" 和 "to" 分别加3天和6天, 如果他们是空的话 [['from', 'to'], 'default', 'value' => function ($model, $attribute) { return date('Y-m-d', strtotime($attribute === 'to' ? '+3 days' : '+6 days')); }], ] ?>
这个验证器不验证数据. 当他们为空的时候.分配给属性值。
value: 表单的默认值 函数原型如下,
<?php function foo($model, $attribute) { // ... 组装 $value ... return $value; } ?>
6. double 浮点值
<?php [ // 检查 "salary" 是一个 double 数字 ['salary', 'double'], ] ?>
相当于一个数字验证器:
max: 数字上限,没设置不检查
min: 数字下线,没设置不检查
7. email 邮箱验证
<?php [ // 检查邮箱是一个有效的 "email"地址 ['email', 'email'], ] ?>