@ php 学习 thinkphp 验证

1,在thinkphp 中可以对create创建的数据对象进行验证 ,一般有两种验证方式: 静态验证,动态验证


   1.1,静态验证: 在模型类里面通过$_validate属性定义验证规则

     (1)验证格式:

        

     array(     
                array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),
          )

          1,验证字段: 为数据表里的字段,同时也可以其他表单辅助字段,并且可以自定义并将自定义的字段映射到数据表的字段名

            如: 

            

       Class UserModel extends Model
            {
               protected $_map = array(
                      'name' =>'username', // 把表单中name映射到数据表的username字段
                      'mail'  =>'email', // 把表单中的mail映射到数据表的email字段
               );
            }

          2,验证规则: 系统还内置了一些常用正则验证的规则 有require (字段必填),email(邮箱格式),

                              url(url格式),currency(货币),number (正整数)   ,integer(整数),double(浮点

                              数),zip(邮政编码),english(英文),并且这些规则默认附加规则是regex, 还有正

                              则表达式验证规则,但需要自定义设定好

          3,错误提示: 自定义

          4,验证条件:

              包含下面几种情况:

self::EXISTS_VALIDATE 或者0 存在字段就验证(默认) 

self::MUST_VALIDATE 或者1 必须验证 

self::VALUE_VALIDATE或者2 值不为空的时候验证 

          5,附加条件: 参考手册 ,其中function  和callback 两种附加条件

              

              5.1 callback 附加规则 ,其定义的验证规则为callback 方法的名字,附加规则为callback


              如下例:

              array(验证字段1,checkLength,错误提示,[验证条件,callback,验证时间,callback函数的参数]),其中checkLength中的$min ,$max 的实参可以定义为 array(3,5)。为$min 传的值为3,$max传的值为5

                protected function checkLength ($str,$min,$max) 
                  {
	                 preg_match_all("/./u",$str,$matches);
	                 $len = count($matches[0]);
	                 if($len<$min || $len>$max){
	                     return false;
	                 }else{
	                   return true;
	                 }
                  }

               5.1 function 附加规则是相对与callback附加规则一样,只是将定义的规则方法,放在    

                     Common 文件下Conmon文件夹建立function.php文件,后会自定调用此规则。     


           6,验证时间:

                           self::MODEL_INSERT或者1新增数据时候验证 

   self::MODEL_UPDATE或者2编辑数据时候验证 

   self::MODEL_BOTH或者3全部情况下验证(默认) 

          7 ,多字段验证:

   在UserModel类中增加 :protected $patchValidate = true;


   (2)静态验证完整格式

     

         public  UserModel extends Model 
        {
	     protected $_validate = array(   
	       array('verify','require','验证码必须!'), //默认情况下用正则进行验证    
               array('name','','帐号名称已经存在!',0,'unique',1), // 在新增的时候验证name字段是否唯一 
               array('password','checkPwd','密码格式不正确',0,'function'), // 自定义函数验证密码格式   );
         }

     根据model定义好验证规则后,就可以在使用create方法创建数据对象的时候自动调用

    

            public UserController extends Controller
           {
     	       public function add ()
     	      {    //判断是由post 上传的数据
	           if(IS_POST){
	              if (!$User->create()){   
	                // 如果创建失败 表示验证没有通过 输出错误提示信息    
	                 exit($User->getError());
	                }else{   
	                  // 验证通过 可以进行其他数据操作
	                }
	           }
     	       }
	
          }

   1.2,动态验证: 使用模型类的validate方法动态创建自动验证规则

       在UserController 类的方法中定义

         $rules = array(    
                        array('verify','require','验证码必须!'), //默认情况下用正则进行验证
                 );
         $User = M("User"); // 实例化User对象
         if (!$User->validate($rules)->create())
         {     
         // 如果创建失败 表示验证没有通过 输出错误提示信息   
           exit($User->getError());
           }else{ 
               // 验证通过 可以进行其他数据操作
                }