当前位置:Gxlcms > PHP教程 > 关于thinkPHP框架自动填充的原理及分析

关于thinkPHP框架自动填充的原理及分析

时间:2021-07-01 10:21:17 帮助过:15人阅读

这篇文章主要介绍了thinkPHP框架自动填充,结合实例形式较为详细的分析了thinkPHP框架自动填充的原理、使用方法及相关操作注意事项,需要的朋友可以参考下

本文实例分析了thinkPHP框架自动填充原理与用法。分享给大家供大家参考,具体如下:

thinkphp有一个自动填充字段的方法

填充规则如下

  1. array(
  2. array(完成字段1,完成规则,[完成条件,附加规则]),
  3. array(完成字段2,完成规则,[完成条件,附加规则]),
  4. ......
  5. );

注:研究源码后发现其实还有第4个参数,是给函数或者回调方法传参数用的,参数1默认为该字段值,如:

  1. array('mobile','trim',3,'function',参数2,参数3'),

验证支付动态和静态

静态验证

在模型类里面预先定义好该模型的自动验证规则,在使用create方法后会自动去验证。

以下是官方的例子

1.首先在模型中定义好验证的规则

  1. namespace Home\Model;
  2. use Think\Model;
  3. class UserModel extends Model{
  4. protected $_auto = array (
  5. array('status','1'), // 新增的时候把status字段设置为1
  6. array('password','md5',3,'function') , // 对password字段在新增和编辑的时候使md5函数处理
  7. array('name','getName',3,'callback'), // 对name字段在新增和编辑的时候回调getName方法
  8. array('update_time','time',2,'function'), // 对update_time字段在更新的时候写入当前时间戳
  9. );
  10. }

2.在调用的时候用create方法会自动进行填充

  1. $User = D("User"); // 实例化User对象
  2. if (!$User->create()){ // 创建数据对象
  3. // 如果创建失败 表示验证没有通过
输出错误提示信息 exit($User->getError()); }else{ // 验证通过 写入新增数据 $User->add(); }

动态验证

以下是官方的例子

  1. $rules = array (
  2. array('status','1'), // 新增的时候把status字段设置为1
  3. array('password','md5',3,'function') , // 对password字段在新增和编辑的时候使md5函数处理
  4. array('update_time','time',2,'function'), // 对update_time字段在更新的时候写入当前时间戳
  5. );
  6. $User = M('User');
  7. $User->auto($rules)->create();
  8. $User->add();

下面是核心的代码分析:

create方法调用后会调用autoOperation方法,方法如下

  1. /**
  2. * 自动表单处理
  3. * @access public
  4. * @param array $data 创建数据
  5. * @param string $type 创建类型
  6. * @return mixed
  7. */
  8. private function autoOperation(&$data,$type) {
  9. if(!empty($this->options['auto'])) {
  10. $_auto = $this->options['auto'];
  11. unset($this->options['auto']);
  12. }elseif(!empty($this->_auto)){
  13. $_auto = $this->_auto;
  14. }
  15. // 自动填充
  16. if(isset($_auto)) {
  17. foreach ($_auto as $auto){
  18. // 填充因子定义格式
  19. // array('field','填充内容','填充条件','附加规则',[额外参数])
  20. if(empty($auto[2])) $auto[2] = self::MODEL_INSERT; // 默认为新增的时候自动填充
  21. //这里的判断是关键,$type为当前的操作状态,值为1表示是插入,值为2表示是更新
  22. //如果当前的$type状态值等于设置的值$auto[2]或者$auto[2]的值为3,代表需要填充
  23. if( $type == $auto[2] || $auto[2] == self::MODEL_BOTH) {
  24. if(empty($auto[3])) $auto[3] = 'string';
  25. switch(trim($auto[3])) {
  26. case 'function': // 使用函数进行填充 字段的值作为参数
  27. case 'callback': // 使用回调方法
  28. $args = isset($auto[4])?(array)$auto[4]:array();
  29. if(isset($data[$auto[0]])) {
  30. array_unshift($args,$data[$auto[0]]);
  31. }
  32. if('function'==$auto[3]) {
  33. $data[$auto[0]] = call_user_func_array($auto[1], $args);
  34. }else{
  35. $data[$auto[0]] = call_user_func_array(array(&$this,$auto[1]), $args);
  36. }
  37. break;
  38. case 'field': // 用其它字段的值进行填充
  39. $data[$auto[0]] = $data[$auto[1]];
  40. break;
  41. case 'ignore': // 为空忽略
  42. if($auto[1]===$data[$auto[0]])
  43. unset($data[$auto[0]]);
  44. break;
  45. case 'string':
  46. default: // 默认作为字符串填充
  47. $data[$auto[0]] = $auto[1];
  48. }
  49. if(isset($data[$auto[0]]) && false === $data[$auto[0]] ) unset($data[$auto[0]]);
  50. }
  51. }
  52. }
  53. return $data;
  54. }

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于smarty循环嵌套的用法

关于PHP编译configure时常见的错误

关于PHP中的静态变量及static静态变量的使用解析

以上就是关于thinkPHP框架自动填充的原理及分析的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行