掌握Thinkphp3.2.0----自动验证

自动验证是TP在create数据的时候,自动对数据进行验证。
TP提供了两种验证方式:静态验证($_validate属性----自定义的模型的)和validate()方法
【掌握Thinkphp3.2.0----自动验证】1.静态验证-----$_validate属性
总体的格式:


验证字段----验证规则-----错误提示-----验证条件-----附加规则----验证时间
红色的是必选字段,黑色的是附加字段
验证字段:顾名思义,就是需要验证的字段
验证规则:系统内置或自定义的规则
错误提示:在验证失败的时候做出的返回的信息
验证条件:
1.self::EXISTS_VALIDATE 或 0,表示存在字段就验证(默认) ;
2.self::MUST_VALIDATE 或 1,表示必须验证;
3.self::VALUE_VALIDATE 或 2,表示值不为空的时候验证。
附近规则:
配合验证规则使用,包括一下规则:

掌握Thinkphp3.2.0----自动验证
文章图片
image 掌握Thinkphp3.2.0----自动验证
文章图片
image
验证时间:
主要新增修改等验证。
1.self::MODEL_INSERT 或 1 新增数据时验证;
2.self::MODEL_UPDATE 或 2 编辑数据时验证;
3.self::MODEL_BOTH 或 3 全部情况下验证(默认)。
自动验证是从上到下以此验证,上面的错误,下面不会有错误信息返回
其实自动验证是很简单的,熟悉规则之后来看一下实例:
内置验证规则:
模型 控制器:create($data)){ echo "验证成功!"; }else{ var_dump($user->getError()); } } }

结果:
掌握Thinkphp3.2.0----自动验证
文章图片
image
附加:
//附加规则regex,验证3-6位纯数字 array('user', '/^\d{3,6}$/', '不是 3-6 位纯正数字', 0, 'regex'), //附加规则equal,验证是否和指定值相等 array('user', '李炎恢', '值不对等', 0, 'equal'), //附加规则notequal,验证是否与指定值不等 array('user', '李炎恢', '值不能相等', 0, 'notequal'), //附加规则confirm,验证两条字段是否相同 array('user', 'name', '两个用户名对比不同!',0,'confirm'), //附加规则in,某个范围,可以是数组或逗号分割的字符串 array('user',array(1,2,3), '不在指定范围', 0, 'in'), array('user', '张三,李四,王五', '不在指定范围', 0, 'in'), //附加规则notin,某个范围,可以是数组或逗号分割的字符串 array('user',array(1,2,3), '不得在指定范围', 0, 'notin'), array('user', '张三,李四,王五', '不得在指定范围', 0, 'notin'), //附加规则length,验证长度或数字范围 array('user', '3', '不得小于 3 位', 0, 'length'), array('user', '3,5', '不得小于 3 位,不得大于 5 位', 0, 'length'), //附加规则between,验证某个范围,数字或逗号字符串 array('user',array(3,5), '必须是 3-5 之间的数字', 0, 'between'), array('user', '3,5', '必须是 3-5 之间的数字', 0, 'between'), //附加规则notbetween,验证某个范围,数字或逗号字符串 array('user',array(3,5), '必须不是 3-5 之间的数字', 0, 'notbetween'), array('user', '3,5', '必须不是 3-5 之间的数字', 0, 'notbetween'), //附加规则expire,设置有效期范围,必须是表单提交有效,可以是时间戳 array('user', '2014-1-10,2015-10-10', '时间已过期', 0, 'expire'), //附加规则ip_deny,IP禁止列表 array('user', '127.0.0.1', '当前 IP 被禁止', 0, 'ip_deny'), //附加规则ip_allow,IP允许列表 array('user', '127.0.0.1', '当前 IP 没有被允许', 0, 'ip_allow'), //附加规则callback,回调验证 array('user', 'checkLength', '用户名必须在 3-5 位', 0, 'callback', 3, array(3,5)), //回调方法 protected n function checkLength($str,$min,$max) { preg_match_all("/./u", $str, $matches); $len = count($matches[0]); if ($len < $min || $len > $max) { returnfalse; }else { returntrue; } } //附加规则function,函数验证 array('user', 'checkLength', '用户名必须在 3-5 位', 0, 'function', 3, array(3,5)), //在 Common 文件夹下的 Common 文件夹建立 function.php 文件,会自动加载 function checkLength($str,$min,$max) { preg_match_all("/./u", $str, $matches); $len = count($matches[0]); if ($len < $min || $len > $max) { returnfalse; } e else { n returntrue; } } 如果有多个字段都包含错误,默认只显示一个错误。如果想显示全部错误,可以设置属 性: //批量验证 d protected $patchValidate =true; 如果是直接 POST 过来的,直接使用 create()方法即可。 //控制器create()方法自动调用验证 $user = D('User'); if ($user->create()) { echo '所有数据验证成功!'; }else { //输出错误信息 var_dump($user->getError()); } PS:由于使用的 UserModel 模型类,所以必须是 D()方法实例化。 如果想把错误信息返回给ajax处理,可以是同ajaxReturn()方法返回JSON数据。 //返回JSON格式 $this->ajaxReturn($user->getError()); //1指定新增数据验证,2表示修改, f if ($user->create($_POST,1)) {} //一般会自动判断

回调和函数是终极的自定义,还是很强大的
2.动态验证----动态验证就是把验证的规则放在控制器端,这样,在操作的时候比较灵活,缺点就是比较混乱。
//动态验证 $rule =array( array('user', 'require', '用户名不得为空'), ); $user = M('User'); $data['user'] = ''; if ($user->validate($rule)->create($data)) { echo '验证所有字段成功!'; } e else { var_dump($user->geterror()); }

    推荐阅读