Yii框架表单模型和验证用法。分享给大家供大家参考,具体如下:
表单模型CFormModel绝大部分继承CModelCModel,由于表模型数据不需要持久化,所以主要在验证操作上。下面以框架脚手架生成的网站登录为例说明表单模型。
1
2
3
4
5
6
7
8
9
|
$model = new LoginForm; //创建一个登录表单模型 $model ->attributes= $_POST [ 'LoginForm' ]; //传入登录数据 CModel->setAttributes( $values , $safeOnly =true) //调用CModel的setter方法 //返回model中relues中定义的安全数据,经过下面的调用流程获取一个验证器集合 //每个验证器由CValidator::createValidator($rule[1],$this,$rule[0],array_slice($rule,2)) CModel->getValidators() ->createValidators() ->rules() CModel->validate(); //遍历验证器执行验证 |
验证器内部实现
表单模型核心部分在验证上,下面探讨其实现方式。
YII框架中验证以独立组件集合的形式存在,CValidator是所有验证器的基类。还是以登录验证为例。rules方法中包含required、boolean、authenticate三个验证器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
public static function createValidator( $name , $object , $attributes , $params = array ()) { if ( is_string ( $attributes )) $attributes =preg_split( '/[s,]+/' , $attributes ,-1,PREG_SPLIT_NO_EMPTY); if (isset( $params [ 'on' ])) { if ( is_array ( $params [ 'on' ])) $on = $params [ 'on' ]; else $on =preg_split( '/[s,]+/' , $params [ 'on' ],-1,PREG_SPLIT_NO_EMPTY); } else $on = array (); if (method_exists( $object , $name )) { $validator = new CInlineValidator; $validator ->attributes= $attributes ; $validator ->method= $name ; if (isset( $params [ 'clientValidate' ])) { $validator ->clientValidate= $params [ 'clientValidate' ]; unset( $params [ 'clientValidate' ]); } $validator ->params= $params ; if (isset( $params [ 'skipOnError' ])) $validator ->skipOnError= $params [ 'skipOnError' ]; } else { $params [ 'attributes' ]= $attributes ; if (isset(self:: $builtInValidators [ $name ])) $className =Yii::import(self:: $builtInValidators [ $name ],true); else $className =Yii::import( $name ,true); $validator = new $className ; foreach ( $params as $name => $value ) $validator -> $name = $value ; } $validator ->on= empty ( $on ) ? array () : array_combine ( $on , $on ); return $validator ; } |
创建验证器流程
1、获取属性(array $attributes)和使用场景(array $on)
2、判断验证器是否存在model中,如果存在创建一个内联验证器CInlineValidator,如果不存在,执行第3步
3、如果验证器是框架自带的导入自带验证器,否则导入外部验证器,然后实例化并赋值。
当触发validate()时候,可能产生的错误将被存储在model中,可以通过调用 CModel::getErrors() 和CModel::getError() 提取这些错误信息
© 版权声明
本文刊载的所有内容,包括文字、图片、音频、视频、软件、程序、以及网页版式设计等部门来源于互联网,版权均归原作者所有!本网站提供的内容服务于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
联系信息:邮箱aoxolcom@163.com或见网站底部。
联系信息:邮箱aoxolcom@163.com或见网站底部。
THE END
请登录后发表评论
注册
社交帐号登录