基于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文本数据库的搜索方法
Oct 09 PHP
PHP中在数据库中保存Checkbox数据(1)
Oct 09 PHP
mysql limit查询优化分析
Nov 12 PHP
使用zend studio for eclipse不能激活代码提示功能的解决办法
Oct 11 PHP
php 将excel导入mysql
Nov 09 PHP
解析php中memcache的应用
Jun 18 PHP
解析PHP中intval()等int转换时的意外异常情况
Jun 21 PHP
php过滤XSS攻击的函数
Nov 12 PHP
php中hashtable实现示例分享
Feb 13 PHP
64位windows系统下安装Memcache缓存
Dec 06 PHP
PHP仿tp实现mvc框架基本设计思路与实现方法分析
May 23 PHP
PHP的new static和new self的区别与使用
Nov 27 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
DOTA2 探索永无止境 玩家自创强悍插眼攻略
2020/04/20 DOTA
php颜色转换函数hex-rgb(将十六进制格式转成十进制格式)
2013/09/23 PHP
Json_decode 解析json字符串为NULL的解决方法(必看)
2017/02/17 PHP
PHP数组访问常用方法解析
2020/09/05 PHP
jQuery表单验证插件formValidator(改进版)
2012/02/03 Javascript
Jquery实现点击切换图片并隐藏显示内容(2种方法实现)
2013/04/11 Javascript
浅析js中的浮点型运算问题
2014/01/06 Javascript
JS面试题---关于算法台阶的问题
2016/07/26 Javascript
Javascript+CSS3实现进度条效果
2016/10/28 Javascript
Boostrap栅格系统与自己额外定义的媒体查询的冲突问题
2017/02/19 Javascript
微信分享调用jssdk实例
2017/06/08 Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
2018/06/14 Javascript
详解Vue+axios+Node+express实现文件上传(用户头像上传)
2018/08/10 Javascript
vue项目刷新当前页面的三种方法
2018/12/04 Javascript
vuex存值与取值的实例
2019/11/06 Javascript
JavaScript实现动态留言板
2020/03/16 Javascript
日常整理python执行系统命令的常见方法(全)
2015/10/22 Python
Python实现TCP协议下的端口映射功能的脚本程序示例
2016/06/14 Python
Python IDLE 错误:IDLE''s subprocess didn''t make connection 的解决方案
2017/02/13 Python
浅谈django开发者模式中的autoreload是如何实现的
2017/08/18 Python
Python元组及文件核心对象类型详解
2018/02/11 Python
对Python的交互模式和直接运行.py文件的区别详解
2019/06/29 Python
Python+Selenium使用Page Object实现页面自动化测试
2019/07/14 Python
如何更换python默认编辑器的背景色
2020/08/10 Python
css3设置box-pack和box-align让div里面的元素垂直居中
2014/09/01 HTML / CSS
物理系毕业生自荐信
2013/11/01 职场文书
七夕活动策划方案
2014/08/16 职场文书
2014年导购员工作总结
2014/11/18 职场文书
2015国庆66周年宣传语
2015/07/14 职场文书
2015年评职称个人工作总结
2015/10/15 职场文书
2016年植树节红领巾广播稿
2015/12/17 职场文书
vue中利用mqtt服务端实现即时通讯的步骤记录
2021/07/01 Vue.js
python中__slots__节约内存的具体做法
2021/07/04 Python
SQL Server数据库基本概念、组成、常用对象与约束
2022/03/20 SQL Server
MySQL 执行数据库更新update操作的时候数据库卡死了
2022/05/02 MySQL
JavaScript实现九宫格拖拽效果
2022/06/28 Javascript