本文将结合实例,讲解如何使用PHP+Mysql完成注册帐号、发送激活邮件、验证激活帐号、处理URL链接过期的功能。
业务流程
1、用户提交注册信息。
2、写入数据库,此时帐号状态未激活。
3、将用户名密码或其他标识字符加密构造成激活识别码(你也可以叫激活码)。
4、将构造好的激活识别码组成URL发送到用户提交的邮箱。
5、用户登录邮箱并点击URL,进行激活。
6、验证激活识别码,如果正确则激活帐号。
准备数据表
用户信息表中字段Email很重要,它可以用来验证用户、找回密码、甚至对网站方来说可以用来收集用户信息进行Email营销,以下是用户信息表t_user的表结构:
DROP TABLE IF EXISTS `wechat_user`;
CREATE TABLE `wechat_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`orgId` int(11) DEFAULT '0' COMMENT '组织ID',
`username` varchar(40) DEFAULT NULL,
`password` varchar(40) NOT NULL,
`nickName` varchar(40) DEFAULT NULL,
`mobile` varchar(20) DEFAULT NULL,
`openId` varchar(50) DEFAULT NULL,
`createTime` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '加入时间',
`checkFlag` int(2) DEFAULT NULL,
`enabled` tinyint(2) DEFAULT '1',
`accessExpires` int(12) DEFAULT NULL,
`accessToken` varchar(128) DEFAULT NULL,
`reTime` varchar(32) DEFAULT NULL,
`email` varchar(128) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=434 DEFAULT CHARSET=utf8 COMMENT='组织和用户关系表';
视图:
<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>
发送邮件:
/**
* 发送邮件
*/
public function send_email()
{
$usernName = I('post.userName','Guest112');
$passWord = I('post.passWord','123456'.rand(1000,9999));
$email = I('post.email','756684177@qq.com');
$reTime = time();
$accessToken = md5($usernName . $passWord . $reTime);//创建用于激活识别码
$accessExpires = $reTime + 60 * 60 * 24; //过期时间为24小时后
$model = M('User');
$data['username'] = $usernName;
$data['password'] = $passWord;
$data['nickName'] = $usernName;
$data['accessToken'] = $accessToken;
$data['accessExpires'] = $accessExpires;
$data['reTime'] = $reTime;
$data['email'] = $email;
$data['enabled'] = 0;
if ($model->add($data) == false) return 'error';
echo 'success';
$link = "http://wechatu.xd107.com/home/Index/activation?accessToken={$accessToken}";
$str = <<<html
您好!<p></p>
感谢您在Tinywan世界注册帐户!<p></p>
帐户需要激活才能使用,赶紧激活成为Tinywan家园的正式一员吧:)<p></p>
点击下面的链接立即激活帐户(或将网址复制到浏览器中打开):<p></p>
$link
html;
$result = send_email($email, 'Tinywan世界帐户激活邮件--' . $usernName, $str);
if ($result['error'] == 1) {
var_dump($result);
die;
}
var_dump('发送完成');
}
激活邮件:
// 用户点击激活方法
public function activation()
{
$accessToken = I('get.accessToken');
$nowTime = time();
$where['enabled'] = 0;
$where['accessToken'] = $accessToken;
$res = M('User')->where($where)->find();
if (!$res) exit('没有改账户');
if ($nowTime > $res['accessexpires']) exit('您的激活有效期已过,请登录您的帐号重新发送激活邮件');
$update = M('User')->where(array('id' => $res['id']))->setField('enabled', 1);
if ($update == false) exit('修改数据库字段失败');
$link = "http://wechatu.xd107.com/home/Index/qrcode?accessToken={$accessToken}"; //这里跳转到一个个人博客的二维码
header('location:' . $link);
}
附:发送邮件方法:
/**
* 发送邮件
* @param string $address 需要发送的邮箱地址 发送给多个地址需要写成数组形式
* @param string $subject 标题
* @param string $content 内容
* @return boolean 是否成功
*/
function send_email($address, $subject, $content)
{
$email_smtp = C('EMAIL_SMTP');
$email_username = C('EMAIL_USERNAME');
$email_password = C('EMAIL_PASSWORD');
$email_from_name = C('EMAIL_FROM_NAME');
if (empty($email_smtp) || empty($email_username) || empty($email_password) || empty($email_from_name)) {
return array("error" => 1, "message" => '邮箱配置不完整');
}
require './ThinkPHP/Library/Org/Nx/class.phpmailer.php';
require './ThinkPHP/Library/Org/Nx/class.smtp.php';
$phpmailer = new \Phpmailer();
// 设置PHPMailer使用SMTP服务器发送Email
$phpmailer->IsSMTP();
// 设置为html格式
$phpmailer->IsHTML(true);
// 设置邮件的字符编码'
$phpmailer->CharSet = 'UTF-8';
// 设置SMTP服务器。
$phpmailer->Host = $email_smtp;
// 设置为"需要验证"
$phpmailer->SMTPAuth = true;
// 设置用户名
$phpmailer->Username = $email_username;
// 设置密码
$phpmailer->Password = $email_password;
// 设置邮件头的From字段。
$phpmailer->From = $email_username;
// 设置发件人名字
$phpmailer->FromName = $email_from_name;
// 添加收件人地址,可以多次使用来添加多个收件人
if (is_array($address)) {
foreach ($address as $addressv) {
$phpmailer->AddAddress($addressv);
}
} else {
$phpmailer->AddAddress($address);
}
// 设置邮件标题
$phpmailer->Subject = $subject;
// 设置邮件正文
$phpmailer->Body = $content;
// 发送邮件。
if (!$phpmailer->Send()) {
$phpmailererror = $phpmailer->ErrorInfo;
return array("error" => 1, "message" => $phpmailererror);
} else {
return array("error" => 0);
}
}
代码详细见:https://github.com/Tinywan/ThinkPhpStudy