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

业务流程

1、用户提交注册信息。

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

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

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

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

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

准备数据表

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

CREATE TABLE `cmf_email`  (
`id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`email` varchar(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '邮箱',
`email_password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '邮箱注册码',
`token` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '账户激活码',
`token_exptime` int(10) NULL DEFAULT NULL COMMENT '激活码有效期',
`status` tinyint(1) NULL DEFAULT 0 COMMENT '状态,0=未激活,1=已激活',
`regtime` int(10) NULL DEFAULT NULL COMMENT '注册时间',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = MyISAM AUTO_INCREMENT = 25 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '//---前台邮箱注册' ROW_FORMAT = Dynamic;

在框架中下载phpmailer包

1.composer require phpmailer/phpmailer

2.在控制器中引入类

use PHPMailer\PHPMailer\PHPMailer

3步骤

<?php
// +----------------------------------------------------------------------
// | ThinkCMF [ WE CAN DO IT MORE SIMPLE ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013-2019 http://www.thinkcmf.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: Powerless < wzxaini9@gmail.com>
// +----------------------------------------------------------------------
namespace app\user\controller; use cmf\controller\HomeBaseController;
use think\Db;
use think\facade\Validate;
use app\user\model\UserModel;
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception; class RegisterController extends HomeBaseController
{ /**
* 前台用户注册
*/
public function index()
{
return $this->fetch('register');
} //发送qq邮箱
/*
* @param
* $address_email --收件人邮箱
* $active_url ---激活地址
* $token --- 账户激活码
* $email_password --邮箱密码
* **/
public function setEmail($address_email, $token, $active_url, $email_password)
{
$sendmail = '135xxx7@qq.com'; //发件人邮箱
//$sendmailpswd = "cbllxxxxxxxhdbc"; //客户端授权密码,而不是邮箱的登录密码!
$sendmailpswd = "olbzxxxxhpqjbfc"; //客户端授权密码,而不是邮箱的登录密码!
$send_name = '悦桔拉拉商城';// 设置发件人信息,如邮件格式说明中的发件人,
$toemail = $address_email;//定义收件人的邮箱
$to_name = '小号';//设置收件人信息,如邮件格式说明中的收件人
$mail = new PHPMailer();
$mail->isSMTP();// 使用SMTP服务
$mail->CharSet = "utf8";// 编码格式为utf8,不设置编码的话,中文会出现乱码
$mail->Host = "smtp.qq.com";// 发送方的SMTP服务器地址
$mail->SMTPAuth = true;// 是否使用身份验证
$mail->Username = $sendmail;//// 发送方的
$mail->Password = $sendmailpswd;//客户端授权密码,而不是邮箱的登录密码!
$mail->SMTPSecure = "ssl";// 使用ssl协议方式
$mail->Port = 465;// qq端口465或587)
// $mail->setFrom($sendmail,$send_name);// 设置发件人信息,如邮件格式说明中的发件人,
$mail->setFrom($sendmail, $send_name);
$mail->addAddress($toemail, $to_name);// 设置收件人信息,如邮件格式说明中的收件人,
$mail->addReplyTo($sendmail, $send_name);// 设置回复人信息,指的是收件人收到邮件后,如果要回复,回复邮件将发送到的邮箱地址
//$mail->addCC("xxx@qq.com");// 设置邮件抄送人,可以只写地址,上述的设置也可以只写地址(这个人也能收到邮件)
//$mail->addBCC("xxx@qq.com");// 设置秘密抄送人(这个人也能收到邮件)
//$mail->addAttachment("bug0.jpg");// 添加附件
$mail->Subject = "悦桔拉拉商城,激活邮箱";// 邮件标题
// $mail->Body = "邮件内容是 <b>您的验证码是:123456</b>,哈哈哈!";// 邮件正文
$mail->Body = "恭喜您,注册成功!请点击链接激活您的帐户:" . "$active_url" . "$token" . "
如果以上链接无法点击,请将它复制到你的浏览器地址栏中进入访问,该链接24小时内有效。";// 邮件正文
//$mail->AltBody = "This is the plain text纯文本";// 这个是设置纯文本方式显示的正文内容,如果不支持Html方式,就会用到这个,基本无用
$token_exptime = time() + 60 * 60 * 24;//过期时间为24小时后
if (!$mail->send()) {// 发送邮件
$this->error('邮箱注册失败!请检查邮箱号码是否正确', url('user/register/index'));
} else {
//将邮箱与密码写入数据库
$data = [
'email' => $address_email,
'email_password' => $email_password,
'token' => $token,
'regtime' => time(),
'token_exptime' => $token_exptime,
];
$res = Db::name('email')->insert($data);
if ($res) {
$this->success('恭喜您,注册成功!<br/>请登录到您的邮箱及时激活您的帐号,然后进行登录!', url('user/login/index'));
}
}
}
  
  //前台注册页面,用户点击提交,跳转到控制器里面的add方法
public function add()
{
if ($this->request->isPost()) { $rules = [
'email' => $this->request->param('email'),
'email_password' => cmf_password($this->request->param('email_password'), $authCode = 'yjllshop'),
];
$nowtime = time(); //当前时间
//对于是否已经注册用户进行判断
$res = Db('email')->where('email', $rules['email'])->find();
if ($res) {
if ($nowtime > $res['token_exptime']) {
$this->error('您的激活有效期已过,请登录您的帐号重新发送激活邮件', url('user/register/index'));
} else {
$this->success('您已经注册过,请直接登录!', url('user/login/index'));
}
}
//dump($rules);die;
//激活地址--对应激活方法
$active_url = 'http://www.yjllshop.com/user/register/valRegister?token='; //调用生产token方法
$token = $this->makeToken($rules['email']);
$this->setEmail($rules['email'], $token, $active_url, $rules['email_password']);
}
} //制作token
public function makeToken($email)
{
$regtime = time();
$num = rand(0, 100);//一段随机数字
$md5Num = md5($regtime . $num . $email);
$token = base64_encode(md5($md5Num)); //创建用于激活识别码 return $token;
} //邮箱激活方法--并且将邮箱的各个信息存放数据库
public function valRegister()
{
//$token
$nowtime = time(); //当前时间
if ($this->request->isGet()) {
$token = $this->request->param('token');
//将条件token值与status=0状态值带入数据库查询,如果能查到,在判断时间是够是过期,就进行激活操作,改变激活码
$res = Db('email')
->where('status', 0)
->where('token', $token)->find();
//dump($res);
/// dump($res['token_exptime']);die;
if ($res) {
if ($nowtime > $res['token_exptime']) {
$this->error('您的激活有效期已过,请登录您的帐号重新发送激活邮件', url('user/register/index'));
} else {
Db::name('email')->where('token', $token)->setField('status', 1);
$this->success('恭喜您,激活成功!<br/>请进行登录!', url('user/login/index'));
}
} else {
$this->error('邮箱注册失败!请检查邮箱号码是否正确', url('user/register/index'));
}
}
//Db::name('email')->insert($user); }
}

  

  

客户端的授权码

注册完成后的数据库

(进阶篇)PHP(thinkphp5框架)实现用户注册后邮箱验证,激活帐号的更多相关文章

  1. PHP用户注册邮箱验证激活帐号

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

  2. ThinkPHP 3.2 用户注册邮箱验证激活帐号

    本文将结合实例,讲解如何使用PHP+Mysql完成注册帐号.发送激活邮件.验证激活帐号.处理URL链接过期的功能. 业务流程 1.用户提交注册信息. 2.写入数据库,此时帐号状态未激活. 3.将用户名 ...

  3. (进阶篇)PHP实现用户注册后邮箱验证,激活帐号

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

  4. PHP用户注册邮箱并验证激活帐号

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

  5. discuz x2.5用户注册后邮箱认证后无法收到邮件或者直接进垃圾箱

    又是一个周末,jquery特效继续折腾我那discuz论坛,我开启了个邮箱验证,恶意注册的太恶心了,没有办法. 能稍微屏蔽点,但是问题来了,据亲们反应,无法收到验证邮件,或者有时间直接进入垃圾箱,这个 ...

  6. Django用户注册、邮箱验证实践

    算法流程如下:1)处理用户注册数据,存入数据库,is_activity字段设置为False,用户未认证之前不允许登陆2)产生token,生成验证连接URL3)发送验证邮件4)用户通过认证邮箱点击验证连 ...

  7. 【从零开始搭建自己的.NET Core Api框架】(七)授权认证进阶篇

    系列目录 一.  创建项目并集成swagger 1.1 创建 1.2 完善 二. 搭建项目整体架构 三. 集成轻量级ORM框架——SqlSugar 3.1 搭建环境 3.2 实战篇:利用SqlSuga ...

  8. C# 使用Emit实现动态AOP框架 进阶篇之异常处理

    目  录 C# 使用Emit实现动态AOP框架 (一) C# 使用Emit实现动态AOP框架 (二) C# 使用Emit实现动态AOP框架 (三) C# 使用Emit实现动态AOP框架 进阶篇之异常处 ...

  9. C# 使用Emit实现动态AOP框架 进阶篇之优化

    目  录 C# 使用Emit实现动态AOP框架 (一) C# 使用Emit实现动态AOP框架 (二) C# 使用Emit实现动态AOP框架 (三) C# 使用Emit实现动态AOP框架 进阶篇之异常处 ...

随机推荐

  1. 数学整合 新(LUOGU)

    1.卡特兰数(P2532) 递推式:h(n)=C(2n,n)/(n+1) (n=0,1,2,...) 前十项(从零开始):1, 1, 2, 5, 14, 42, 132, 429, 1430, 486 ...

  2. 关于MySQL在内网中使用另一台机器访问的问题

    要在内网中访问另一台机器的MySQL数据库,需要两步操作 一是把运行MySQL的机器的3306端口打开,最好是能限制访问IP保证安全性. 二是更改MySQL账户的访问权限.MySQL的root账户默认 ...

  3. asp.net请求编译流程图(其实就是说asp.netd代码是如何转成中间代码IL然后交给cpu执行的)

  4. Spring boot 默认静态资源路径与手动配置访问路径的方法

    这篇文章主要介绍了Spring boot 默认静态资源路径与手动配置访问路径的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下   在application.propertis中配置 ##端口号 ...

  5. Jigloo 下载 安装 GUI

    这个需要授权,一直不能解决!! 网上找了很多,都觉不能访问,这个可以用Eclipse直接更新的 http://www.cloudgardensoftware.com/jigloo/update-sit ...

  6. java网络爬虫实现信息的抓取

    转载请注明出处:http://blog.csdn.NET/lmj623565791/article/details/23272657 今天公司有个需求,需要做一些指定网站查询后的数据的抓取,于是花了点 ...

  7. 2018.09.11 loj#10216.五指山(exgcd)

    传送门 就是一个exgcd的板子. 但注意算距离差的时候是在一个环上面算. 还有,答案要开long long233... 注意这两点之后就是exgcd板子了. 代码: #include<bits ...

  8. mysql 经典错误解决方案 :Incorrect string value 'xE6x95x85xE4xBAx8B...' for column

    1.关闭当前服务器2.删除正在使用的数据库drop database 数据库名字;3.查看字符集, SHOW VARIABLES LIKE 'character_set_%'; 把所有latin1的都 ...

  9. DataFrame按行读取:DataFrame之values

    http://blog.csdn.net/u014607457/article/details/51290582 def fill_core(self): RatingTable=pd.read_cs ...

  10. MySQL Yum存储库 安装、升级、集群

    添加MySQL Yum存储库 首先,将MySQL Yum存储库添加到系统的存储库列表中.按着这些次序: 在http://dev.mysql.com/downloads/repo/yum/上转到MySQ ...