- 笔者前段接了一个项目,其中包含了一个用户注册系统,用到了密码找回功能,简单整理一下,写点心得。时间仓促,如有笔误,请大大们指点(phpsoho.com@gmail.com)。
-
- 首先,我们假定你已经有了一个用户注册系统。其中用户表可能如下:
-
- create table member(
- id int unsigned not null auto_incremtnt,
- username………………
- passwords char(32) not null,
- email varchar(100) not null,
- ……………………………..
- );
-
- 现在讨论的焦点不是数据库设计,我们主要谈密码找回。
-
- 我们可以选择的密码找回方案可能有以下几种:
- 1. 用户预设找回密码问题,并且提供找回密码答案。
- 2. 用户通过email 找回密码
- ……………………..
-
- 第一种方案或许是个很好的解决方案,但我们这次并不选择此方案,其中的种种原因,也不在本讨论之内。我们用第二种方案作为本次的主要讨论对象。
-
- 那么我们开始吧。
-
- 第二种方案的其中好处是:
- 1. 注册用户必须提供正确的邮箱,否则将不能使用系统所提供的密码重设功能。
- 2. 必须由该用户通过邮箱确认。
- 这可能对企业来说,是件好事。企业总是费劲心思的想得到用户真实的详细信息,以便进行有针对性的邮件列表服务。这也是这次开发用户要求这样做的一个主要原因。
-
- 我们可能会在login界面提供一个链接,或者在login失败后提供一个链接。链接名当然你可以自己定义了,我定义的是:忘了密码,需要找回吗?
-
- 当用户点击找加密码时,我们会提供一个input表单。让用户输入用户名(如果是login失败后,我们可以用session填充表单内容)。用户点击提交后,我们开始我们的密码重设功能流程。
-
- 我们可能会创建这样一个文件 send_reset_pass_mail.php。这个文件主要负责产生一个通过GET方法传递的字符串,并且将其发送出去。
-
- 代码可能如下:
- PHP代码:
- <?php
-
-
-
- require_once(‘config.inc.php’);
-
-
-
-
- require_once(‘sendMail.inc.php’);
-
-
-
-
-
-
- $username = trim($_POST[‘username’]);
-
- $sql = “select email,passwords from member where username = ‘”.trim($_POST[‘username’]).“‘”;
- $userInfo = $db->FetchRow($sql);
-
- $user_pass = $userInfo[‘passwords’];
- $user_email = $userInfo[’email’];
-
-
-
-
-
-
- $x = md5($username.’+’.$passwords);
-
- $String = base64_encode($username.“.”.$x);
-
- $sendMail = new sendMail();
- $subject = “你的密码找回信”;
- $message = “尊敬的”.$username.“先生/女士:<br /> 你使用了本站提供的密码找回功能,如果你确认此密码找回功能是你启用的,请点击下面的链接,按流程进行密码重设。<br><br>欢迎你经常访问本站。站长无喱头谢谢你经常光顾本站!<br><Br><a href=’/resetUserPass.php?p=”.$String.“>确认密码找回</a>”;
-
- if( $sendMail->mailto($user_email,$subject,$message) )
- {
-
- }
- else
- {
- die(“由于xx原因,你执行的找回密码未能成功!请登陆网站,与站长联系。谢谢”);
- }
- ?>
-
-
-
-
- 那么好,我们的信件已经成功发出了,哪么用户得到了一个什么样的链接呢?
- 可能如下:
- /resetUserPass.php?p=dT1saXRvdSZ4PTAwZTc1MGZlNmZjOGNkNGYyMjgzMDA3MWJlZDNmZTAw
-
- 用户点击过后,执行我们站点的resetUserPass.php程序。
-
- PHP代码:
-
- <?php
- require_once(‘config.inc.php’);
-
-
-
- $array = explode(‘.’,base64_decode($_GET[‘p’]));
-
-
-
-
-
-
-
-
- $sql = “select passwords from member where username = ‘”.trim($_array[‘0‘]).“‘”;
-
- $passwords = $db->GetOne($sql);
-
-
-
-
- $checkCode = md5($array[‘0‘].’+’.$passwords);
-
-
-
-
-
- if( $array[‘1‘] === $checkCode ){
-
- Echo “<input name=username value='”.$array[‘0‘].“‘ onlyread>”;
- Echo “<input name=userpasswd type=password>”;
- Echo “<input name=reinput type=password>”;
- }else{
-
- }
-
-
- ?>
-
-
- 然后用户进行login。
-
-
- 本实例在:linux for debian,php4.3.1,mysql4.1.0,apache1.3下通过。
php 找回密码