基于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 选项及相关信息函数库
Dec 04 PHP
IIS6的PHP最佳配置方法
Mar 19 PHP
关于PHP实现异步操作的研究
Feb 03 PHP
php缩小png图片不损失透明色的解决方法
Dec 25 PHP
PHP远程采集图片详细教程
Jul 01 PHP
php导出CSV抽象类实例
Sep 24 PHP
PHP之将POST数据转化为字符串的实现代码
Nov 03 PHP
PHP实现对xml进行简单的增删改查(CRUD)操作示例
May 19 PHP
PHP7.1实现的AES与RSA加密操作示例
Jun 15 PHP
laravel-admin的多级联动方法
Sep 30 PHP
PHP常用函数之获取汉字首字母功能示例
Oct 21 PHP
PhpStorm的使用教程(本地运行PHP+远程开发+快捷键)
Mar 26 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
PHP 应用程序的安全 -- 不能违反的四条安全规则
2006/11/26 PHP
解析MySql与Java的时间类型
2013/06/22 PHP
修改ThinkPHP缓存为Memcache的方法
2014/06/25 PHP
php判断邮箱地址是否存在的方法
2016/02/13 PHP
Thinkphp整合微信支付功能
2016/12/14 PHP
PHP脚本自动识别验证码查询汽车违章
2016/12/20 PHP
多个iframe自动调整大小的问题
2006/09/18 Javascript
效率高的Javscript字符串替换函数的benchmark
2008/08/02 Javascript
一段实现页面上的图片延时加载的js代码
2010/02/11 Javascript
jquery.simple.tree插件 更简单,兼容性更好的无限树插件
2010/09/03 Javascript
sails框架的学习指南
2014/12/22 Javascript
jQuery手机拨号界面特效代码分享
2015/08/27 Javascript
jquery实现移动端点击图片查看大图特效
2020/09/11 Javascript
jQuery动画效果图片轮播特效
2016/01/12 Javascript
jQuery Ajax 全局调用封装实例代码详解
2016/06/02 Javascript
BootStrap下拉框在firefox浏览器界面不友好的解决方案
2016/08/18 Javascript
微信小程序 生命周期和页面的生命周期详细介绍
2017/01/19 Javascript
nodejs图片处理工具gm用法小结
2018/12/12 NodeJs
vue中get请求如何传递数组参数的方法示例
2019/11/08 Javascript
js中位数不足自动补位扩展padLeft、padRight实现代码
2020/04/06 Javascript
Python实现合并字典的方法
2015/07/07 Python
浅谈python中截取字符函数strip,lstrip,rstrip
2015/07/17 Python
轻松掌握python设计模式之策略模式
2016/11/18 Python
Python实现的多项式拟合功能示例【基于matplotlib】
2018/05/15 Python
英国马匹装备和马术用品购物网站:Equine Superstore
2019/03/03 全球购物
德国药房apodiscounter中文官网:德国排名前三的网上药店
2019/06/03 全球购物
美国名表在线商城:Ashford(支持中文)
2019/09/24 全球购物
考试没考好检讨书
2014/01/31 职场文书
大学生求职工作的自我评价
2014/02/13 职场文书
学校元旦晚会方案
2014/02/19 职场文书
考察现实表现材料
2014/05/19 职场文书
企业趣味活动方案
2014/08/21 职场文书
2015年度房地产工作总结
2015/04/09 职场文书
关于成立领导小组的通知
2015/04/23 职场文书
演讲开场白和结束语
2015/05/29 职场文书
MySQL Innodb关键特性之插入缓冲(insert buffer)
2021/04/08 MySQL