一般说来,程序猿永远不应该信任从最终用户直接接收到的数据, 并且使用它们之前应始终先验证其可靠性。
要给 model 填充其所需的用户输入数据,你可以调用 yii\base\Model::validate() 方法验证它们。该方法会返回一个布尔值,指明是否通过验证。下面列举一些常用的rulse验证规则:
整数:
[['pid', 'sort', 'update_time', 'create_time', 'update_uid', 'create_uid'], 'integer'],
必填:
[['name'], 'required','message'=>'{attribute}不能为空'],
字数限制:
[['name'], 'string','min' => 2, 'max' => 10],
尺寸限制:
[['poster_temp_img'], 'image', 'extensions' => 'png, jpg','minWidth' => 750, 'maxWidth' => 750,'minHeight' => 1373, 'maxHeight' => 1373],
唯一:
[['title'], 'unique'],
删除左右空格:
[['logo_x', 'logo_y'], 'trim'],
某范围内:
[['logo_ext'], 'in', 'range' => [0, 1, 2]],
电子邮箱:
['email', 'email'],
URL链接:
[['ad_url_one'], 'url', 'defaultScheme' => 'http', 'on'=>['create', 'update']], 支持类似www.baidu.com
若 "level" 为空,则设其为 1:['level', 'default', 'value' => 1],
required : 必须值验证属性
[['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息']; #说明:CRequiredValidator 的别名, 确保了特性不为空.
email : 邮箱验证
['email', 'email']; #说明:CEmailValidator的别名,确保了特性的值是一个有效的电邮地址.
match : 正则验证
[['字段名'],match,'pattern'=>'正则表达式','message'=>'提示信息'];
[['字段名'],match,'not'=>ture,'pattern'=>'正则表达式','message'=>'提示信息']; /*正则取反*/ #说明:CRegularExpressionValidator 的别名, 确保了特性匹配一个正则表达式.
url : 网址
['website', 'url', 'defaultScheme' => 'http']; #说明:CUrlValidator 的别名, 确保了特性是一个有效的路径.
captcha : 验证码
['verificationCode', 'captcha']; #说明:CCaptchaValidator 的别名,确保了特性的值等于 CAPTCHA 显示出来的验证码.
safe : 安全
['description', 'safe'],
compare : 比较
['age', 'compare', 'compareValue' => 30, 'operator' => '>='], #说明:compareValue(比较常量值) - operator(比较操作符) #说明:CCompareValidator 的别名,确保了特性的值等于另一个特性或常量.
default : 默认值
['age', 'default', 'value' => null], #说明:CDefaultValueValidator 的别名, 为特性指派了一个默认值.
exist : 存在
['username', 'exist'], #说明:CExistValidator 的别名,确保属性值存在于指定的数据表字段中.
file : 文件
['primaryImage', 'file', 'extensions' => ['png', 'jpg', 'gif'], 'maxSize' => 1024*1024*1024]; #说明:CFileValidator 的别名, 确保了特性包含了一个上传文件的名称.
filter : 滤镜
[['username', 'email'], 'filter', 'filter' => 'trim', 'skipOnArray' => true], #说明:CFilterValidator 的别名, 使用一个filter转换属性.
in : 范围
['level', 'in', 'range' => [1, 2, 3]], #说明:CRangeValidator 的别名,确保了特性出现在一个预订的值列表里.
unique : 唯一性
['username', 'unique'], #说明:CUniqueValidator 的别名,确保了特性在数据表字段中是唯一的.
integer : 整数
['age', 'integer'],
number : 数字
['salary', 'number'],
double : 双精度浮点型
['salary', 'double'],
date : 日期
[['from', 'to'], 'date'],
string : 字符串
['username', 'string', 'length' => [4, 24]],
boolean : 是否为一个布尔值
['字段名', 'boolean', 'trueValue' => true, 'falseValue' => false, 'strict' => true], #说明:CBooleanValidator 的别名