我的编程空间,编程开发者的网络收藏夹
学习永远不晚

thinkphp5.0修改器和数据完成关系的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

thinkphp5.0修改器和数据完成关系的示例分析

小编给大家分享一下thinkphp5.0修改器和数据完成关系的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

密码加密时遇到的问题

今天遇到密码md5加密的问题,当时使用的是 "thinkphp5.0.9->模型->数据完成" 实现的自动进行加密,但是在上面 "thinkphp5.0.9->模型->修改器" 中发现修改器和数据完成功能一样,看下方的评论说是数据完成和修改器配合使用,我就照着做,当时这样写的:
//模型层class User extends Model{//$auto包含新增$insert和更新操作$update,就是不管新增还是更新我就自动执行    protected $auto = ['password','create'];    public function setPasswordAttr($value)    {        return md5($value);    }    public function setCreateAttr()    {        return time();    }    //注册用户    public function register($data){            $bool = $this->save($data);            return $bool ? $this->id : 0;    } }//控制器层方法public function register()    {        if(request()->isAjax()){            $userModel=new \app\index\Model\User();            $data=input('post.');//注册            $res = $userModel->register($data);           echo $res;        }else{            $this->error('非法访问');        }    }

thinkphp5.0修改器和数据完成关系的示例分析

我输入 "wwwwww" 按照上面的代码进行注册后password加密结果是b8d3c8f4db0c248ac242dd6e098bbf85

正确的加密结果是 d785c99d298a4e9e6e13fe99e602ef42,这个时候你可能没发现,当你登陆的时候就是登陆不上去,你肯定再去注册一个新用户,比如密码还是wwwwww,你登陆的时候还是登陆不上去,只能怀疑加密出错,再往上找到了 "数据完成的setPasswordAttr()"

单独拿出来测试

直接说答案吧,我当时看了多遍修改器和数据完成测试两个小时终于知道原因了,新建的test表

thinkphp5.0修改器和数据完成关系的示例分析

//新建test模型层namespace app\index\Model;use think\Model;class Test extends Model{    protected $auto = ['password'];    protected function setPasswordAttr($value)    {        dump(md5(NULL));        dump($value);        dump(md5($value));        return md5($value);    }    public function addPass(){        echo "修改器";        $this->password='wwwwww';        dump($this->password);                echo "数据完成";        $this->save([            'username'  => 'thinkphp',            'password'  => 'wwwwww',            'create'    => '123456'        ]);    }}//控制器中添加test方法 public function test(){        $user = model('Test');        //调用model层函数        $user->addPass();    }

单独测试修改器

首先注释掉模型层中的 “数据完成” 部分
namespace app\index\Model;use think\Model;class Test extends Model{    protected $auto = ['password'];    protected function setPasswordAttr($value)    {        dump(md5(NULL));//把NULL加密        dump($value);   //查看调用时传递过来的值        dump(md5($value));//把该值加密        return md5($value);//把该值加密返回    }    public function addPass(){        echo "修改器:修改器的作用是可以在数据赋值的时候自动进行转换处理";        $this->password='wwwwww';        dump($this->password);//输出返回后的结果//        echo "数据完成:在数据字段insert,update,auto时进行处理";//        $this->save([//            'username'  => 'thinkphp',//            'password'  => 'wwwwww',//            'create'    => '123456'//        ]);    }}
执行后页面显示结果,通过结果发现修改器是在赋值的时候执行的自动加密,注意:此时并没有存入数据库!
修改器:修改器的作用是可以在数据赋值的时候自动进行转换处理string(32) "d41d8cd98f00b204e9800998ecf8427e"【加密的NULL】string(6) "wwwwww"【传过来的$value】string(32) "d785c99d298a4e9e6e13fe99e602ef42"【加密$value】string(32) "d785c99d298a4e9e6e13fe99e602ef42"【return返回的结果】

测试数据完成

注释掉“修改器”部分的代码,仅执行数据完成
namespace app\index\Model;use think\Model;class Test extends Model{    protected $auto = ['password'];    protected function setPasswordAttr($value)    {        dump(md5(NULL));//把NULL加密        dump($value);   //查看调用时传递过来的值        dump(md5($value));//把该值加密        return md5($value);//把该值加密返回    }    public function addPass(){//        echo "修改器:修改器的作用是可以在数据赋值的时候自动进行转换处理";//        $this->password='wwwwww';//        dump($this->password);//输出返回后的结果        echo "数据完成:在数据字段insert,update,auto时进行处理";        $this->save([            'username'  => 'thinkphp',            'password'  => 'wwwwww',            'create'    => '123456'        ]);    }}

找到原因

执行后发现setPasswordAttr()被执行了两次,所以password也被加密了两次;
数据完成:在数据字段insert,update,auto时进行处理string(32) "d41d8cd98f00b204e9800998ecf8427e"【加密NULL】string(6) "wwwwww"【传入的$value】string(32) "d785c99d298a4e9e6e13fe99e602ef42"【加密$value="wwwwww"】string(32) "d41d8cd98f00b204e9800998ecf8427e"【加密NULL】string(32) "d785c99d298a4e9e6e13fe99e602ef42"【传入的$value】string(32) "b8d3c8f4db0c248ac242dd6e098bbf85"【再次加密$value="d785c99...f42"】
加密两次的原因是在赋值的时候加密一次,自动完成$auto时加密了一次
[    'username'  => 'thinkphp',    'password'  => 'wwwwww',    'create'    => '123456']

解决开始的问题

如果想要加密一次就把 protected $auto = ['password']; 注释掉,或者在登陆的代码中进行md5(md5("wwwwww")),注释掉后执行:
数据完成:在数据字段insert,update,auto时进行处理string(32) "d41d8cd98f00b204e9800998ecf8427e"【加密NULL】string(6) "wwwwww"【$value】string(32) "d785c99d298a4e9e6e13fe99e602ef42"【加密结果】

thinkphp5.0修改器和数据完成关系的示例分析

如果是多个字段protected $auto = ['password','create'];就把password去掉就可以了protected $auto = ['create'];,所以最开始的问题就解决了。

当只有数据完成但不赋值

在上面可能注意到我怎么老是加密 NULL 干什么,还有另一种情况就是 protected $auto = ['password']; 定义了自动完成,但是我并没有赋值:
namespace app\index\Model;use think\Model;class Test extends Model{    protected $auto = ['password'];    protected function setPasswordAttr($value)    {        dump(md5(NULL));//把NULL加密        dump($value);   //查看调用时传递过来的值        dump(md5($value));//把该值加密        return md5($value);//把该值加密返回    }    public function addPass(){//        echo "修改器:修改器的作用是可以在数据赋值的时候自动进行转换处理";//        $this->password='wwwwww';//        dump($this->password);//输出返回后的结果        echo "数据完成:在数据字段insert,update,auto时进行处理";        $this->save([            'username'  => 'thinkphp',//注释掉,不赋值 //           'password'  => 'wwwwww',            'create'    => '123456'        ]);    }}
执行后,加密的是 NULL
数据完成:在数据字段insert,update,auto时进行处理string(32) "d41d8cd98f00b204e9800998ecf8427e"【加密NULL】NULL【没有传值,$value=NULL】string(32) "d41d8cd98f00b204e9800998ecf8427e"【加密$value,刚好等于NULL加密结果】
剩下的$update和$insert使用方法同$auto一样,$auto包含$update和$insert

总结

修改器会在赋值时执行;数据完成会被执行两次,一次是赋值时,一次是写入数据时
希望手册能稍微详细一点点,白白耽误我开发时间,特此分享,大家少踩坑,如果理解的不对请指正,谢谢

以上是“thinkphp5.0修改器和数据完成关系的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

thinkphp5.0修改器和数据完成关系的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

thinkphp5.0修改器和数据完成关系的示例分析

小编给大家分享一下thinkphp5.0修改器和数据完成关系的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!密码加密时遇到的问题今天遇到密码md5加密的问
2023-06-14

NumPy中的线性关系与数据修剪压缩实例分析

这篇文章主要介绍“NumPy中的线性关系与数据修剪压缩实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“NumPy中的线性关系与数据修剪压缩实例分析”文章能帮助大家解决问题。摘要总结股票均线计算
2023-06-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录