会员邮箱验证,邮箱验证的目的就是解决会员密码忘记后怎样找回,可是当我们整合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}}
新闻热点
疑难解答