THINKPHP 中密码在编辑中不填写即不修改,ignore和md5冲突的解决办法

在使用THINKPHP自动完成功能时,对于密码在编辑时,不填写则不修改密码,我是这样解决的:


在_auto自动完成中

 protected $_auto = array(

        array('admin_password','md5',3,'function'), 
        array('admin_password','',2,'ignore'),   //判断密码为空时候忽略 3.1以上版本

);

如果先使用MD5加密,获取到的空密码被加密为32位的码文了,导致下面  ignore 判断就无效了。


如果使用:

 protected $_auto = array(


        array('admin_password','',2,'ignore'),   
        array('admin_password','md5',3,'function'), 
);

则admin_password首先被忽略掉,后面MD5加密又对此为空的密码加密了。


所以怎么弄都不行,百度网上内容,有人修改THINKPHP的模型文件,此操作不可取。


还有一种办法是使用钩子函数,before_update 大概类似这样的,在数据编辑进入数据表时候调用这个函数。


但是我想了想,既然3.1版本出了这个ignore的参数,应该有办法在自动完成中能够完成上述问题。经过思考,如下:


protected $_auto = array(

        array('admin_password','md5',3,'function'),//所有情况下设置密码为MD5加密
        array('admin_password','repassword',2,'callback'),   //编辑情况下调用repassword方法
        array('admin_password','',2,'ignore'),
  );


 protected  function repassword($admin_password){

         if($admin_password == 'd41d8cd98f00b204e9800998ecf8427e' ){
           return '';
       }else  return $admin_password;
   }


先对密码进行MD5加密,然后在编辑情况下调用repassword方法,判断如果是空的MD5码文,则返回空,否则返回本身;


 array('admin_password','',2,'ignore'),

然后这句话对调用回来的密码再进行是否为空判断,为空则忽略,不修改密码。


经测试,搞定!哈哈哈







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值