码迷,mamicode.com
首页 > 其他好文 > 详细

自动验证[2]

时间:2015-05-13 18:59:12      阅读:146      评论:0      收藏:0      [点我收藏+]

标签:

附加规则expire,设置有效期范围,必须是表单提交有效,可以是时间戳

这时,在 Home/controller/UserController.class.php 中插入

 1 public function add() {
 2             $user=D(‘User‘);
 3       
 4             $data[‘user‘]=‘‘;
 5             if($user->create($data)) {
 6                 echo ‘所有字段验证成功‘;
 7             }else {
 8                 var_dump($user->getError());
 9             }
10         }

因为$data[‘user‘]在验证的时候不是验证这里有没有值,而是验证表单提交的时间,而且,如果不是表单提交,直接执行add()函数是没有用的还是会出错。

 

 Home/Model/UserModel.class.php 插入以下代码:

 1 <?php
 2 namespace Home\Model;
 3 use Think\Model;
 4 
 5 class UserModel extends Model {
 6     protected $_validate= array(
 7         array(‘user‘, ‘2014-1-10,2015-10-10‘, ‘时间已过期‘, 0, ‘expire‘),
 8         );
 9     
10 }

这时验证的时间是 ‘2014-1-10,2015-10-10‘ 以内,

 

然后在index.html(与主目录下的index.php是同级的)插入以下代码:

1 <meta charset="utf-8">
2 <form method="post" action="http://localhost/demo39/index.php/Home/User/add">
3   <p>用户:<input type="text" name="yonghu" /></p>
4   <p>邮箱:<input type="text" name="youxiang" /></p>
5   <input type="submit" value="提交">
6 </form>

注意,这里不要加上输入的时间,

 

附加规则callback,回调验证

在 Home/controller/UserController.class.php 插入以下代码:

1 public function add() {
2             $user=D(‘User‘);
3             $data[‘user‘]=‘zdp‘;
4             if($user->create($data)) {
5                 echo ‘所有字段验证成功‘;
6             }else {
7                 var_dump($user->getError());
8             }
9         }

然后在 Home/Model/UserModel.class.php 插入验证的代码:

 1 <?php
 2 namespace Home\Model;
 3 use Think\Model;
 4 
 5 class UserModel extends Model {
 6     protected $_validate= array(
 7         array(‘user‘, ‘checkLength‘, ‘用户名必须在 3-5 位‘, 0, ‘callback‘, 3,array(3,5)),//v这里的array(3,5)是checkLength内的$min和$maxl两个参数
 8         );
 9     protected function checkLength($str,$min,$max) {
10         preg_match_all("/./", $str, $matches);   //如果验证的是中文,则正则为"/./u",后面的u是utf8编码格式
11         $len =count($matches[0]);
12         if($len<$min||$len>$max) {
13             return false;
14         } else {
15             return true;
16         }
17     }
18     
19 }

 

附加规则function,函数验证

在 Home/Model/UserModel.class.php 内代码为:

 

1 <?php
2 namespace Home\Model;
3 use Think\Model;
4 
5 class UserModel extends Model {
6     protected $_validate= array(
7         array(‘user‘, ‘checkLength‘, ‘用户名必须在 3-5 位‘, 0, ‘function‘, 3,array(3,5)),//v这里的array(3,5)是checkLength内的$min和$maxl两个参数
8         );
9 }

 

然后在 Common 文件夹下的 Common 文件夹建立 function.php 文件,会自动加载

写入以下代码:

 1 <?php
 2  function checkLength($str,$min,$max) {
 3         preg_match_all("/./", $str, $matches);   //如果验证的是中文,则正则为"/./u",后面的u是utf8编码格式
 4         $len =count($matches[0]);
 5         if($len<$min||$len>$max) {
 6             return false;
 7         } else {
 8             return true;
 9         }
10     }

 

如果有多个字段都包含错误,默认只显示一个错误。如果想显示全部错误,可以设置属性:

1 protected $patchValidate =  true;

这时在 Home/controller/UserController.class.php 内插入:

 1 public function add() {
 2             $user=D(‘User‘);
 3             $data[‘user‘]=‘‘;
 4             $data[‘email‘] =‘bbbb‘;
 5             if($user->create($data)) {
 6                 echo ‘所有字段验证成功‘;
 7             }else {
 8                 var_dump($user->getError());
 9             }
10         }

然后在 Home/Model/UserModel.class.php 内插入:

 1 <?php
 2 namespace Home\Model;
 3 use Think\Model;
 4 
 5 class UserModel extends Model {
 6     protected $_validate= array(
 7         array(‘user‘, ‘require‘, ‘用户名不得为空‘, 0, ‘regex‘, 3),
 8         array(‘email‘, ‘email‘, ‘邮箱格式不正确‘),
 9         );
10     protected $patchValidate = true;
11 }

这时才会将两个错误都显示出来

技术分享

如果想把错误信息返回给ajax处理,可以是同ajaxReturn()方法返回JSON数据。

 

1 //返回JSON格式
2 $this->ajaxReturn($user->getError());

这时在原先在 Home/controller/UserController.class.php 使用的错误显示时用的 var_dump($user->getError()); 改为 $this->ajaxReturn($user->getError()); 

错误信息显示如下:

技术分享

 

还有一个就是

1 //1指定新增数据验证,2表示修改,
2  if ($user->create($_POST,1)) {} //一般会自动判断,就是表单提交时根据信息来判断提交来的数据是新增还是修改

 

三. 动态验证

动态验证就是把验证的规则放在控制器端,这样,在操作的时候比较灵活,缺点就是比较混乱。

 

 1 public function add() {
 2             $rule = array(
 3                 array(‘user‘,‘require‘,‘用户名不得为空‘),
 4                 );
 5             $user=M(‘User‘);
 6             $data[‘user‘]=‘‘;
 7             $data[‘email‘] =‘123‘;
 8             if($user->validate($rule)->create($data)) {
 9                 echo ‘所有字段验证成功‘;
10             }else {
11                 var_dump($user->getError());
12             }
13         }

这时判定提交的数据必须加上 validate($rule) ,要不然就直接验证为‘所有字段验证成功‘

 

自动验证[2]

标签:

原文地址:http://www.cnblogs.com/jacson/p/4500995.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!