PHP找回密码机制流程

笔者前段接了一个项目,其中包含了一个用户注册系统,用到了密码找回功能,简单整理一下,写点心得。

首先,我们假定你已经有了一个用户注册系统。其中用户表可能如下:

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
/**
* 我们假设你已经在config.inc.php文件里配置好了你的sql信息,mail信息
*/
require_once('config.inc.php');

/**
* 你需要一下sendmail类来进行邮件发送,我们也假设你已经配置好,并且能正发送邮件
*/
require_once('sendMail.inc.php');

/**
* 首先我们执行查询,得到此用户的相关信息
* 你不要告诉我你不知道$_POST['username']是怎么得到的,假如是这样,我郁闷一下你。
* 我使用了adodb的类,并且已经在配置文件中声明过
*/
$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'];

/**
* OK,一些需要的东西我们都有了,看来得进行下步操作了
* 现在让我们产生一个经过md5加密码过的字符串,先不要问为什么,等会再告诉你
*/

$x = md5($username.' '.$passwords);
//现在我们可以发送邮件给用户了。当然,我们还得需要另一个密码重设程序 resetUserPass.php
$String = base64_encode($username.".".$x);

时间: 2024-10-23 12:52:23

PHP找回密码机制流程的相关文章

ThinkPHP 3.2 用户注册邮箱验证帐号找回密码

一.前言 当然现在有的网站也有手机短信的方式找回密码,原理就是通过发送验证码来验明正身,和发送邮件验证一样,最终还是要通过重置密码来完成找回密码的流程. 本文将使用PHP+Mysql+jQuery来实现一个密码找回的功能,一般步骤是: 1.表单输入注册时的邮箱: 2.验证用户邮箱是否正确,如果用户邮箱不存在网站的用户表中,则提示用户邮箱未注册: 3.发送邮件,如果用户邮箱确实存在用户表中,则组合用于验证用户信息的字符串,并构造URL发送到用户邮箱中; 4.用户登录邮箱收取邮件,点击URL链接到网

帮助用户解决登录困难:忘记密码和找回密码的设计

文章描述:注册那点事之--忘记密码?还是找回密码? 上次我们聊到了关于用户来到你的网站,如何让用户心甘情愿注册,以及如何在注册中为用户设置与产品定位相符的注册填写项.今天我们来聊一个看似平淡无奇而事实上和每个用户账号息息相关的问题:用户无法登录自己的账号时该怎么办? 用户无法登录自己的账号,看到产品界面上硕大的红色"用户名或密码错误"之类的提示自然是心急如焚.好在当前涉及用户账号的产品都有完备的账号安全机制,无论用户的用户名忘了,还是不记得密码了,都提供了完善的应急机制.虽然看起来各个

新浪微博如何使用绑定手机找回密码?

  登录密码找回页,选择"其他方式找回",按流程引导填写您的登录名和验证码确定后,选择"使用绑定手机找回密码",输入绑定手机号,填写手机接收到的验证码,验证成功后输入新密码即可.

java web激活邮箱并找回密码_java

几乎每个网站或论坛之类的用户注册后都需要通过发送邮件到邮箱激活用户,如何激活邮箱呐? 设计激活步骤: 1.发送激活操作链接地址至用户邮箱. 2.用户至邮箱查收邮件. 3.用户点击链接,跳转至成功页面(修改激活状态),激活成功. 实现: /** * 发送邮件 * * @param request * @return */ @RequestMapping(value = "/sendEmail.jhtml") @ResponseBody public String sendEmail(Ht

如何实现用邮箱找回密码?

问题描述 请问如何实现用邮箱找回密码?java代码如何实现? 解决方案 解决方案二:可以发一封带url.连接的邮件给用户,提示用户点击url找回密码,用户点击url的时候,后台取得url里的参数(标识),然后进行业务处理:解决方案三:用什么实现不重要.重要的是中间的流程合理与否.安全性做的到位否解决方案四:菜鸟一枚,坐等大师来解答,学习中--解决方案五:一楼正解----解决方案六:有个找回密码功能就是邮箱找回的.action中findPassWord()方法.Mail类...好好研究下,这个模仿

金山毒霸如何找回密码

  如果您的帐号购买过金山网游,那么需要到网游处http://my.xoyo.com/find/index找回密码,如果您的帐号没有购买过金山网游,可以通过以下两种方式找回: 1. 已经绑定过邮箱或手机 如果您的帐号已经绑定过邮箱或手机,可在帐号中心找回密码,通过您绑定的邮箱或手机即可迅速找回密码. 2. 未绑定过邮箱或手机 如果您的帐号未绑定过邮箱或手机,您可以联系客服人员帮您解决问题.

如何通过网页版飞信找回密码

如果用户忘记了飞信登录密码,在登录页面中,点击"忘记密码"链接,进入找回密码页面.输入要找回密码的帐号(手机号.飞信号或邮箱均可),点击"下一步"按钮,根据页面提示进行操作即可. 注: 1.密码需由6-16位数字.字母或符号组成,区分大小写,密码中必须同时包含字母及数字. 2.不允许使用中文.全角字符.

多米音乐盒如何找回密码

  多米音乐盒找回密码的方法如下: 1)官网 在官网首页,点击右上角登录-忘记密码. 2)手机多米 塞班:菜单-常用工具-账号管理-菜单-找回密码. 3)电脑多米 在电脑乐库界面,点击忘记密码. 找回密码的途径: 1)通过邮箱找回 填写注册的邮箱,多米会自动将修改密码的链接发送到邮箱中,点击链接进行密码修改. 2) 通过手机号找回 填写手机号,多米会自动将修改密码的链接以短信的方式发送到手机,点击链接进行密码.

彩云忘记密码怎么办(怎么找回密码)?

  如果您忘记密码,可使用短信密码登录,也可使用找回密码功能.您可在彩云任意客户端的登录页面,点击"找回密码"(或"忘记密码"),按照提示内容操作,即可找回密码.