通过PHP实现用户注册后邮箱验证激活


Posted in PHP onNovember 10, 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;

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

<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中支持多种编码的中文字符串截取函数!
Mar 20 PHP
php inc文件使用的风险和注意事项
Nov 12 PHP
PHP封装分页函数实现文本分页和数字分页
Oct 23 PHP
PHP判断网络文件是否存在的方法
Mar 12 PHP
php写入、删除与复制文件的方法
Jun 20 PHP
PHP读取文件的常见几种方法
Nov 03 PHP
解决PHP程序运行时:Fatal error: Maximum execution time of 30 seconds exceeded in的错误提示
Nov 25 PHP
php实现不通过扩展名准确判断文件类型的方法【finfo_file方法与二进制流】
Apr 18 PHP
Laravel中log无法写入问题的解决
Jun 17 PHP
PHP实现的各类hash算法长度及性能测试实例
Aug 27 PHP
在Laravel5.6中使用Swoole的协程数据库查询
Jun 15 PHP
PHP中的异常处理机制深入讲解
Nov 10 #PHP
基于php解决json_encode中文UNICODE转码问题
Nov 10 #PHP
ThinkPHP5分页paginate代码实例解析
Nov 10 #PHP
关于PHP求解三数之和问题详析
Nov 09 #PHP
PHP中isset、empty的用法与区别示例详解
Nov 05 #PHP
PHP后门隐藏的一些技巧总结
Nov 04 #PHP
phpstudy2020搭建站点的实现示例
Oct 30 #PHP
You might like
PHP调用MsSQL Server 2012存储过程获取多结果集(包含output参数)的详解
2013/07/03 PHP
php页面防重复提交方法总结
2013/11/25 PHP
Apache无法自动跳转却显示目录的解决方法
2020/11/30 PHP
JavaScript 事件参考手册
2008/12/24 Javascript
改进UCHOME的记录发布,增强可访问性用户体验
2011/01/17 Javascript
轻量级网页遮罩层jQuery插件用法实例
2015/07/31 Javascript
如何实现移动端浏览器不显示 pc 端的广告
2015/10/15 Javascript
详解Jquery实现ready和bind事件
2016/04/14 Javascript
解决拦截器对ajax请求的拦截实例详解
2016/12/21 Javascript
Nodejs基于LRU算法实现的缓存处理操作示例
2017/03/17 NodeJs
Express URL跳转(重定向)的实现方法
2017/04/07 Javascript
AngularJS读取JSON及XML文件的方法示例
2017/05/25 Javascript
Bootstrap模态框插入视频的实现代码
2017/06/25 Javascript
详解vuex结合localstorage动态监听storage的变化
2018/05/03 Javascript
JavaScript运行机制实例分析
2020/04/11 Javascript
vue开发简单上传图片功能
2020/06/30 Javascript
ES2020系列之空值合并运算符 '??'
2020/07/22 Javascript
浅谈python字符串方法的简单使用
2016/07/18 Python
浅谈python 读excel数值为浮点型的问题
2018/12/25 Python
Python递归函数实例讲解
2019/02/27 Python
对Python 检查文件名是否规范的实例详解
2019/06/10 Python
对Python函数设计规范详解
2019/07/19 Python
python 处理微信对账单数据的实例代码
2019/07/19 Python
Python中print函数简单使用总结
2019/08/05 Python
python使用socket实现的传输demo示例【基于TCP协议】
2019/09/24 Python
Python3 操作 MySQL 插入一条数据并返回主键 id的实例
2020/03/02 Python
friso美素佳儿官方海外旗舰店:荷兰原产原罐
2017/07/03 全球购物
四年大学自我鉴定
2014/02/17 职场文书
开学典礼策划方案
2014/05/28 职场文书
防邪知识进家庭活动方案
2014/08/26 职场文书
校运动会广播稿300字
2014/10/07 职场文书
工程部经理岗位职责
2015/02/02 职场文书
圆明园观后感
2015/06/03 职场文书
《时代广场的蟋蟀》读后感:真挚友情,温暖世界!
2020/01/08 职场文书
React中的Context应用场景分析
2021/06/11 Javascript
Python之基础函数案例详解
2021/08/30 Python