会员邮箱验证,邮箱验证的目的就是解决会员密码忘记后怎样找回,可是当我们整合discuz论坛后,会发现我们从网站找回密码的功能不能用,当用户从邮箱收到找回密码的验证信息后,修改的密码不起作用,我一开始也遇到这样的问题,我一开始还以为dede出问题了,我又重新测试了一次,发现dede并没有错误,后来我又详细看了一下代码,发现会员修改密码时候并没有写入到ucenter里面,出现这个问题,我感觉是由于dede和dz的安装顺序有问题吧,大家都知道dz6.0之后的dz整合都是通过uc来做的,我是先安装的dede,这样会出现一些未知的错误吧,我也不想重新再装了,说不定装上之后还不知道行不行,所以还是自己将它写入到uc里面吧.
打开member下的resetpassword.php文件,找到大概134行:
- if($pwd == $pwdok)
 - {
 - $pwdok = md5($pwdok);
 - $sql = "DELETE FROM `dede_pwd_tmp` WHERE `mid` = '$id';";
 - $db->executenonequery($sql);
 - $sql = "UPDATE `dede_member` SET `pwd` = '$pwdok' WHERE `mid` = '$id';";
 - if($db->executenonequery($sql))
 - {
 - showmsg('更改密码成功,请牢记新密码', 'login.php');
 - exit;
 - }
 - }
 - //修改为:
 - if($pwd == $pwdok)
 - {
 - #api{{
 - if(defined('UC_API') && @include_once DEDEROOT.'/uc_client/client.php')
 - {
 - $row1 = $db->GetOne("Select * From dede_member where mid = '$mid'");
 - $ucresult = uc_user_edit($row1['userid'], '', $pwdok, '', 1);
 - }
 - #/aip}}
 - $pwdok = md5($pwdok);
 - $sql = "DELETE FROM `dede_pwd_tmp` WHERE `mid` = '$id';";
 - $db->executenonequery($sql);
 - $sql = "UPDATE `dede_member` SET `pwd` = '$pwdok' WHERE `mid` = '$id';";
 - if($db->executenonequery($sql))
 - {
 - showmsg('更改密码成功,请牢记新密码', 'login.php');
 - exit;
 - }
 - }
 
主要是在修改密码之前加入写入uc的代码:
- #api{{
 - if(defined('UC_API') && @include_once DEDEROOT.'/uc_client/client.php')
 - {
 - $row1 = $db->GetOne("Select * From dede_member where mid = '$mid'");
 - $ucresult = uc_user_edit($row1['userid'], '', $pwdok, '', 1);
 - }
 - #/aip}}
 
新闻热点
疑难解答