最近突然发现,Thinkphp自动验证很奇怪的失效,开始并没有在意,因为class名写错了,修改就好了,后来发现在对于model里面写了自定义的验证方法的时候就不对了,因为习惯性的喜欢复制比如收藏的个别的语句,方便使用,挨个写感觉费事,于是就复制了这么一句:
protected $_validate = array( array('verify','require','验证码必须!'), // 都有时间都验证 array('name','checkName','帐号错误!',1,'function',4), // 只在登录时候验证 array('password','checkPwd','密码错误!',1,'function',4), // 只在登录时候验证 );第三、四行,倒数第二个参数是function,而在下面写的是一个自定义的方法:
protected function checkPWD(){ if(1){//演示使用,随便写的 return false; }else{ return true; } }但是始终就是不能正常的返回验证结果,后来才发现原来是function的问题,查看一下自动验证部分的源代码,如下:
/** * 根据验证因子验证字段 * @access protected * @param array $data 创建数据 * @param array $val 验证因子 * @return boolean */ protected function _validationFieldItem($data,$val) { switch(strtolower(trim($val[4]))) { case 'function':// 使用函数进行验证 case 'callback':// 调用方法进行验证 $args = isset($val[6])?(array)$val[6]:array(); if(is_string($val[0]) && strpos($val[0], ',')) $val[0] = explode(',', $val[0]); if(is_array($val[0])){ // 支持多个字段验证 foreach($val[0] as $field) $_data[$field] = $data[$field]; array_unshift($args, $_data); }else{ array_unshift($args, $data[$val[0]]); } if('function'==$val[4]) { return call_user_func_array($val[1], $args); }else{ return call_user_func_array(array(&$this, $val[1]), $args); } case 'confirm': // 验证两个字段是否相同 return $data[$val[0]] == $data[$val[1]]; case 'unique': // 验证某个值是否唯一 if(is_string($val[0]) && strpos($val[0],',')) $val[0] = explode(',',$val[0]); $map = array(); if(is_array($val[0])) { // 支持多个字段验证 foreach ($val[0] as $field) $map[$field] = $data[$field]; }else{ $map[$val[0]] = $data[$val[0]]; } $pk = $this->getPk(); if(!empty($data[$pk]) && is_string($pk)) { // 完善编辑的时候验证唯一 $map[$pk] = array('neq',$data[$pk]); } if($this->where($map)->find()) return false; return true; default: // 检查附加规则 return $this->check($data[$val[0]],$val[1],$val[4]); } }当是function的时候使用的是函数进行验证,其实说白了就是比如用Application/Common/function.php类似位置的自定义函数进行处理,很明显当前model里面的方法并不适用,只有当这里是callback的时候才会调用自定义的model内的方法。

我的微信:graent_hu
欢迎扫码加我的微信好友,有什么问题我们可以一起探讨,有什么需要也随时欢迎发消息给我~
转载请注明出处:
本文标题:粗心!Thinkphp(3.2.x)自动验证中function和callback的区别
本文链接:https://www.wlyc.cn/post-72.html
发表评论