当前位置:首页 > CMS教程 > Discuz > 列表

关于discuz与dede整合无法找回密码的问题

发布:smiling 来源: PHP粉丝网  添加日期:2014-04-02 16:44:29 浏览: 评论:0 

会员邮箱验证,邮箱验证的目的就是解决会员密码忘记后怎样找回,可是当我们整合discuz论坛后,会发现我们从网站找回密码的功能不能用,当用户从邮箱收到找回密码的验证信息后,修改的密码不起作用,我一开始也遇到这样的问题,我一开始还以为dede出问题了,我又重新测试了一次,发现dede并没有错误,后来我又详细看了一下代码,发现会员修改密码时候并没有写入到ucenter里面,出现这个问题,我感觉是由于dede和dz的安装顺序有问题吧,大家都知道dz6.0之后的dz整合都是通过uc来做的,我是先安装的dede,这样会出现一些未知的错误吧,我也不想重新再装了,说不定装上之后还不知道行不行,所以还是自己将它写入到uc里面吧.

打开member下的resetpassword.php文件,找到大概134行:

  1. if($pwd == $pwdok
  2. $pwdok = md5($pwdok); 
  3. $sql = "DELETE FROM `dede_pwd_tmp` WHERE `mid` = '$id';"
  4. $db->executenonequery($sql); 
  5. $sql = "UPDATE `dede_member` SET `pwd` = '$pwdok' WHERE `mid` = '$id';"
  6. if($db->executenonequery($sql)) 
  7. showmsg('更改密码成功,请牢记新密码''login.php'); 
  8. exit
  9. //修改为:  
  10. if($pwd == $pwdok
  11. #api{{ 
  12. if(defined('UC_API') && @include_once DEDEROOT.'/uc_client/client.php'
  13. $row1 = $db->GetOne("Select * From dede_member where mid = '$mid'"); 
  14. $ucresult = uc_user_edit($row1['userid'], ''$pwdok'', 1); 
  15. #/aip}} 
  16. $pwdok = md5($pwdok); 
  17. $sql = "DELETE FROM `dede_pwd_tmp` WHERE `mid` = '$id';"
  18. $db->executenonequery($sql); 
  19. $sql = "UPDATE `dede_member` SET `pwd` = '$pwdok' WHERE `mid` = '$id';"
  20. if($db->executenonequery($sql)) 
  21. showmsg('更改密码成功,请牢记新密码''login.php'); 
  22. exit

主要是在修改密码之前加入写入uc的代码:

  1. #api{{ 
  2. if(defined('UC_API') && @include_once DEDEROOT.'/uc_client/client.php'
  3. $row1 = $db->GetOne("Select * From dede_member where mid = '$mid'"); 
  4. $ucresult = uc_user_edit($row1['userid'], ''$pwdok'', 1); 
  5. #/aip}} 

Tags: discuz dede 密码 问题

分享到: