基于PHP实现邮箱验证激活过程详解


Posted in PHP onOctober 28, 2020

我们在很多网站注册会员时,注册完成后,系统会自动向用户的邮箱发送一封邮件,这封邮件的内容就是一个URL链接,用户需要点击打开这个链接才能激活之前在该网站注册的帐号。激活成功后才能正常使用会员功能。

本文将结合实例,讲解如何使用PHP+Mysql完成注册帐号、发送激活邮件、验证激活帐号、处理URL链接过期的功能。

业务流程

1、用户提交注册信息。

2、写入数据库,此时帐号状态未激活。

3、将用户名密码或其他标识字符加密构造成激活识别码(你也可以叫激活码)。

4、将构造好的激活识别码组成URL发送到用户提交的邮箱。

5、用户登录邮箱并点击URL,进行激活。

6、验证激活识别码,如果正确则激活帐号。

准备数据表

用户信息表中字段Email很重要,它可以用来验证用户、找回密码、甚至对网站方来说可以用来收集用户信息进行Email营销,以下是用户信息表t_user的表结构:

CREATE TABLE IF NOT EXISTS `t_user` ( 
 `id` int(11) NOT NULL AUTO_INCREMENT, 
 `username` varchar(30) NOT NULL COMMENT '用户名', 
 `password` varchar(32) NOT NULL COMMENT '密码', 
 `email` varchar(30) NOT NULL COMMENT '邮箱', 
 `token` varchar(50) NOT NULL COMMENT '帐号激活码', 
 `token_exptime` int(10) NOT NULL COMMENT '激活码有效期', 
 `status` tinyint(1) NOT NULL DEFAULT '0' COMMENT '状态,0-未激活,1-已激活', 
 `regtime` int(10) NOT NULL COMMENT '注册时间', 
 PRIMARY KEY (`id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

HTML

在页面中放置一个注册表单,用户可以输入注册信息,包括用户名、密码和邮箱。

<form id="reg" action="register.php" method="post"> 
  <p>用户名:<input type="text" class="input" name="username" id="user"></p> 
  <p>密 码:<input type="password" class="input" name="password" id="pass"></p> 
  <p>E-mail:<input type="text" class="input" name="email" id="email"></p> 
  <p><input type="submit" class="btn" value="提交注册"></p> 
</form>

对于用户的输入要进行必要的前端验证,关于表单验证功能,建议您参考本站文章:实例讲解表单验证插件Validation的应用,本文对前端验证代码略过,另外其实页面中还应该有个要求用户重复输入密码的输入框,一时偷懒就此略过。

register.php

用户将注册信息提交到register.php进行处理。register.php需要完成写入数据和发送邮件两大功能。

首先包含必要的两个文件,connect.php和smtp.class.php,这两个文件在外面提供的下载包里有,欢迎下载。

include_once("connect.php");//连接数据库
include_once("smtp.class.php");//邮件发送类

然后我们要过滤用户提交的信息,并验证用户名是否存在(前端也可以验证)。

$username = stripslashes(trim($_POST['username'])); 
$query = mysql_query("select id from t_user where username='$username'"); 
$num = mysql_num_rows($query); 
if($num==1){ 
  echo '用户名已存在,请换个其他的用户名'; 
  exit; 
}

接着我们将用户密码加密,构造激活识别码:

$password = md5(trim($_POST['password'])); //加密密码
$email = trim($_POST['email']); //邮箱
$regtime = time();
$token = md5($username.$password.$regtime); //创建用于激活识别码
$token_exptime = time()+60*60*24;//过期时间为24小时后
$sql = "insert into `t_user` (`username`,`password`,`email`,`token`,`token_exptime`,`regtime`)
values ('$username','$password','$email','$token','$token_exptime','$regtime')";
mysql_query($sql);

上述代码中,$token即构造好的激活识别码,它是由用户名、密码和当前时间组成并md5加密得来的。$token_exptime用于设置激活链接URL的过期时间,用户在这个时间段内可以激活帐号,本例设置的是24小时内激活有效。最后将这些字段插入到数据表t_user中。

当数据插入成功后,调用邮件发送类将激活信息发送给用户注册的邮箱,注意将构造好的激活识别码组成一个完整的URL作为用户点击时的激活链接,以下是详细代码:

if(mysql_insert_id()){ 
  $smtpserver = ""; //SMTP服务器,如:smtp.163.com 
  $smtpserverport = 25; //SMTP服务器端口,一般为25 
  $smtpusermail = ""; //SMTP服务器的用户邮箱,如xxx@163.com 
  $smtpuser = ""; //SMTP服务器的用户帐号xxx@163.com 
  $smtppass = ""; //SMTP服务器的用户密码 
  $smtp = new Smtp($smtpserver, $smtpserverport, true, $smtpuser, $smtppass); //实例化邮件类 
  $emailtype = "HTML"; //信件类型,文本:text;网页:HTML 
  $smtpemailto = $email; //接收邮件方,本例为注册用户的Email 
  $smtpemailfrom = $smtpusermail; //发送邮件方,如xxx@163.com 
  $emailsubject = "用户帐号激活";//邮件标题 
  //邮件主体内容 
  $emailbody = "亲爱的".$username.":<br/>感谢您在我站注册了新帐号。<br/>请点击链接激活您的帐号。<br/> 
  <a href='http://www.helloweba.com/demo/register/active.php?verify=".$token."' target= 
'_blank'>http://www.helloweba.com/demo/register/active.php?verify=".$token."</a><br/> 
  如果以上链接无法点击,请将它复制到你的浏览器地址栏中进入访问,该链接24小时内有效。"; 
  //发送邮件 
  $rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype); 
  if($rs==1){ 
    $msg = '恭喜您,注册成功!<br/>请登录到您的邮箱及时激活您的帐号!';   
  }else{ 
    $msg = $rs;   
  } 
} 
echo $msg;

还有一个相当好用且强大的邮件发送类分享个大家:使用PHPMailer发送带附件并支持HTML内容的邮件,直接可以用哦。

active.php

如果不出意外,您注册帐号时填写的Email将收到一封helloweba发送的邮件,这个时候您直接点击激活链接,交由active.php处理。

active.php接收提交的链接信息,获取参数verify的值,即激活识别码。将它与数据表中的用户信息进行查询对比,如果有相应的数据集,判断是否过期,如果在有效期内则将对应的用户表中字段status设置1,即已激活,这样就完成了激活功能。

include_once("connect.php");//连接数据库 
 
$verify = stripslashes(trim($_GET['verify'])); 
$nowtime = time(); 
 
$query = mysql_query("select id,token_exptime from t_user where status='0' and 
`token`='$verify'"); 
$row = mysql_fetch_array($query); 
if($row){ 
  if($nowtime>$row['token_exptime']){ //24hour 
    $msg = '您的激活有效期已过,请登录您的帐号重新发送激活邮件.'; 
  }else{ 
    mysql_query("update t_user set status=1 where id=".$row['id']); 
    if(mysql_affected_rows($link)!=1) die(0); 
    $msg = '激活成功!'; 
  } 
}else{ 
  $msg = 'error.';   
} 
echo $msg;

激活成功后,发现token字段并没有用处了,您可以清空。接下来我们会讲解用户找回密码的功能,也要用到邮箱验证,敬请关注。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP中的CMS的涵义
Mar 11 PHP
Apache+php+mysql在windows下的安装与配置图解(最新版)
Nov 30 PHP
PHP在线生成二维码代码(google api)
Jun 03 PHP
PHP递归遍历指定目录的文件并统计文件数量的方法
Mar 24 PHP
php实现的RSS生成类实例
Apr 23 PHP
WordPress后台中实现图片上传功能的实例讲解
Jan 11 PHP
YII动态模型(动态表名)支持分析
Mar 29 PHP
PHP简单实现生成txt文件到指定目录的方法
Apr 25 PHP
PHP创建多级目录的两种方法
Oct 28 PHP
PHP simplexml_import_dom()函数讲解
Feb 03 PHP
PHP实现发送微博消息功能完整示例
Dec 04 PHP
PHP读取Excel内的图片(phpspreadsheet和PHPExcel扩展库)
Nov 19 PHP
THINKPHP5分页数据对象处理过程解析
Oct 28 #PHP
Laravel 自动转换长整型雪花 ID 为字符串的实现
Oct 27 #PHP
Laravel配合jwt使用的方法实例
Oct 25 #PHP
数据结构之利用PHP实现二分搜索树
Oct 25 #PHP
如何运行/调试你的PHP代码
Oct 23 #PHP
php redis setnx分布式锁简单原理解析
Oct 23 #PHP
PHP如何通过带尾指针的链表实现'队列'
Oct 22 #PHP
You might like
JS异常处理try..catch语句的作用和实例
2014/05/05 PHP
PHP生成指定随机字符串的简单实现方法
2015/04/01 PHP
PHP实现简单的新闻发布系统实例
2015/07/28 PHP
分享五个PHP7性能优化提升技巧
2015/12/07 PHP
Twig模板引擎用法入门教程
2016/01/20 PHP
PHP 二维数组和三维数组的过滤
2016/03/16 PHP
用js查找法实现当前栏目的高亮显示的代码
2007/11/24 Javascript
[原创]IE view-source 无法查看看源码 JavaScript看网页源码
2009/07/19 Javascript
分享一个我自己写的ToolTip提示插件(附源码)
2013/01/20 Javascript
图片动画横条广告带上下滚动的JS代码
2013/10/25 Javascript
jquery如何获取复选框的值
2013/12/12 Javascript
深入理解javascript中的立即执行函数(function(){…})()
2014/06/12 Javascript
使用jquery prev()方法找到同级的前一个元素
2014/07/11 Javascript
JavaScript实现的背景自动变色代码
2015/10/17 Javascript
基于JavaScript实现动态添加删除表格的行
2016/02/01 Javascript
JQuery实现文字无缝滚动效果示例代码(Marquee插件)
2017/03/07 Javascript
禁止弹窗中蒙层底部页面跟随滚动的几种方法
2017/12/07 Javascript
JS实现的DOM插入节点操作示例
2018/04/04 Javascript
JS中的算法与数据结构之字典(Dictionary)实例详解
2019/08/20 Javascript
JS实现“全选”和&quot;全不选&quot;功能代码实例
2020/02/06 Javascript
Django1.7+python 2.78+pycharm配置mysql数据库
2016/10/09 Python
浅谈python新式类和旧式类区别
2019/04/26 Python
pytorch中获取模型input/output shape实例
2019/12/30 Python
tensorflow 重置/清除计算图的实现
2020/01/19 Python
html5 自定义播放器核心代码
2013/12/20 HTML / CSS
Raffaello Network德国:意大利拉斐尔时尚购物网
2019/05/01 全球购物
求职者应聘的自我评价
2013/10/16 职场文书
小学生安全保证书
2014/02/01 职场文书
政风行风评议整改方案
2014/09/15 职场文书
2014年办公室主任工作总结
2014/11/12 职场文书
学籍证明模板
2014/11/21 职场文书
写给同学的新学期寄语
2015/02/27 职场文书
中秋节晚会开场白
2015/05/29 职场文书
MySQL的索引你了解吗
2022/03/13 MySQL
漫画「日和酱的要求是绝对的」第3卷封面公开
2022/03/21 日漫
Java版 单机五子棋
2022/05/04 Java/Android