zoukankan      html  css  js  c++  java
  • ThinkPHP:create()方法有什么用呢?

    1.create方法可以对POST提交的数据进行处理(通过表中的字段名称与表单提交的名称对应关系自动封装数据实例),例如user表中有一个字段名叫"username",如果表单中有一个<input name="username" value="小明">,那么$User = M('User'); $data = $User->create(); echo $data['username'];就会输出"小明",不用你用$_POST['username']去接收。
    2.用create方法可以对表单进行令牌验证,防止表单重复提交。
    3.可以对数据自动验证,前提是你必须手动在Model文件夹中建立一个UserModel.class.php文件,在其中加入验证规责
        protected $_validate    =    array(
                array('username','require','用户名必须', 1),
            );
    4.可以对字段自动赋值,前提还是必须手动在Model文件夹中建立一个UserModel.class.php文件,在其中加入
        protected $_auto = array(
                array('create_time','time',self::MODEL_INSERT,'function'),
            );
        那么user的注册时间将自动赋值为当前时间

    附上create方法的源码:
        /**
         * 创建数据对象 但不保存到数据库
         * @access public
         * @param mixed $data 创建数据
         * @param string $type 状态
         * @return mixed
         */
         public function create($data='',$type='') {
            // 如果没有传值默认取POST数据
            if(empty($data)) {
                $data   =   $_POST;
            }elseif(is_object($data)){
                $data   =   get_object_vars($data);
            }
            // 验证数据
            if(empty($data) || !is_array($data)) {
                $this->error = L('_DATA_TYPE_INVALID_');
                return false;
            }

            // 检查字段映射
            $data = $this->parseFieldsMap($data,0);

            // 状态
            $type = $type?$type:(!empty($data[$this->getPk()])?self::MODEL_UPDATE:self::MODEL_INSERT);

            // 检测提交字段的合法性
            if(isset($this->options['field'])) { // $this->field('field1,field2...')->create()
                $fields =   $this->options['field'];
                unset($this->options['field']);
            }elseif($type == self::MODEL_INSERT && isset($this->insertFields)) {
                $fields =   $this->insertFields;
            }elseif($type == self::MODEL_UPDATE && isset($this->updateFields)) {
                $fields =   $this->updateFields;
            }
            if(isset($fields)) {
                if(is_string($fields)) {
                    $fields =   explode(',',$fields);
                }
                // 判断令牌验证字段
                if(C('TOKEN_ON'))   $fields[] = C('TOKEN_NAME');
                foreach ($data as $key=>$val){
                    if(!in_array($key,$fields)) {
                        unset($data[$key]);
                    }
                }
            }

            // 数据自动验证
            if(!$this->autoValidation($data,$type)) return false;

            // 表单令牌验证
            if(C('TOKEN_ON') && !$this->autoCheckToken($data)) {
                $this->error = L('_TOKEN_ERROR_');
                return false;
            }

            // 验证完成生成数据对象
            if($this->autoCheckFields) { // 开启字段检测 则过滤非法字段数据
                $fields =   $this->getDbFields();
                foreach ($data as $key=>$val){
                    if(!in_array($key,$fields)) {
                        unset($data[$key]);
                    }elseif(MAGIC_QUOTES_GPC && is_string($val)){
                        $data[$key] =   stripslashes($val);
                    }
                }
            }

            // 创建完成对数据进行自动处理
            $this->autoOperation($data,$type);
            // 赋值当前数据对象
            $this->data =   $data;
            // 返回创建的数据以供其他调用
            return $data;
         }

    add方法就简单了,
    1.对create方法中创建的数据对象进行插入数据库。
    例如:
    $User = M('User');
    $User->create(array('username'=>'小明')); //这里没有从表单接收数据

    $User->add();
    将会生成insert into think_uesr ('username')values('小明')
    2.可以进行数据中回调处理,类似于java中Spring框架的AOP思想,前提还是必须手动在Model文件夹中建立一个UserModel.class.php文件,在其中加入
        // 插入数据前的回调方法
        protected function _before_insert(&$data,$options) {

        }
        // 插入成功后的回调方法
        protected function _after_insert($data,$options) {
        
        }
        在插入之前做些什么在_before_insert中写自己的逻辑,在插入之后做些什么在_after_insert中写自己的逻辑。

  • 相关阅读:
    使用ShareSDK完成第三方(QQ、微信、微博)登录和分享
    Https适配
    AFNetworking实现程序重新启动时的断点续传
    开源Word读写组件DocX 的深入研究和问题总结
    ITTC数据挖掘平台介绍(四) 框架改进和新功能
    聪明的投资者读书笔记1
    word中公式居中编号在最右端
    tensorflow中使用Batch Normalization
    财务自由之路读书笔记二
    mybatis与mysql中的Date和String之间转换
  • 原文地址:https://www.cnblogs.com/wicub/p/4470470.html
Copyright © 2011-2022 走看看