PHP實(shí)現(xiàn)的激活用戶注冊驗(yàn)證郵箱功能示例
本文實(shí)例講述了PHP實(shí)現(xiàn)的激活用戶注冊驗(yàn)證郵箱功能。分享給大家供大家參考,具體如下:
這里將結(jié)合實(shí)例介紹如何使用PHP+Mysql完成注冊帳號、發(fā)送激活郵件、驗(yàn)證激活帳號、處理URL鏈接過期的功能。
注冊郵箱激活流程
1、用戶注冊
2、插入用戶數(shù)據(jù),此時(shí)帳號未激活狀態(tài)。
3、將用戶名密碼或其他標(biāo)識字符加密構(gòu)造成激活識別碼(你也可以叫激活碼)。
4、將構(gòu)造好的激活識別碼組成URL發(fā)送到用戶提交的郵箱。
5、用戶登錄郵箱并點(diǎn)擊URL,進(jìn)行激活。
6、驗(yàn)證激活識別碼,如果正確則激活帳號。
t_user.sql
用戶信息表中字段Email很重要,它可以用來驗(yàn)證用戶、找回密碼、甚至對網(wǎng)站方來說可以用來收集用戶信息進(jìn)行Email營銷,以下是用戶信息表t_user的表結(jié)構(gòu):
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 '狀態(tài),0-未激活,1-已激活', `regtime` int(10) NOT NULL COMMENT '注冊時(shí)間', 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>
register.php完成寫入數(shù)據(jù)和發(fā)送郵件
首先連接數(shù)據(jù)庫 和包含郵件發(fā)送類 smtp.class.php
include_once("connect.php");//連接數(shù)據(jù)庫
include_once("smtp.class.php");//郵件發(fā)送類
前端驗(yàn)證表單我們省略了,直接看程序
$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;
}
接著我們將用戶密碼加密,構(gòu)造激活識別碼:
$password = md5(trim($_POST['password'])); //加密密碼
$email = trim($_POST['email']); //郵箱
$regtime = time();
$token = md5($username.$password.$regtime); //創(chuàng)建用于激活識別碼
$token_exptime = time()+60*60*24;//過期時(shí)間為24小時(shí)后
$sql = "insert into `t_user` (`username`,`password`,`email`,`token`,`token_exptime`,`regtime`)
values ('$username','$password','$email','$token','$token_exptime','$regtime')";
mysql_query($sql);
上述代碼中,$token即構(gòu)造好的激活識別碼,它是由用戶名、密碼和當(dāng)前時(shí)間組成并md5加密得來的。$token_exptime用于設(shè)置激活鏈接URL的過期時(shí)間,用戶在這個時(shí)間段內(nèi)可以激活帳號,本例設(shè)置的是24小時(shí)內(nèi)激活有效。最后將這些字段插入到數(shù)據(jù)表t_user中。
當(dāng)數(shù)據(jù)插入成功后,調(diào)用郵件發(fā)送類將激活信息發(fā)送給用戶注冊的郵箱,注意將構(gòu)造好的激活識別碼組成一個完整的URL作為用戶點(diǎn)擊時(shí)的激活鏈接,以下是詳細(xì)代碼:
if (mysql_insert_id()) {//寫入成功,發(fā)郵件
include_once("smtp.class.php");
$smtpserver = "smtp.163.com"; //SMTP服務(wù)器
$smtpserverport = 25; //SMTP服務(wù)器端口
$smtpusermail = "hjl416148489_4@163.com"; //SMTP服務(wù)器的用戶郵箱
$smtpuser = "hjl416148489_4@163.com"; //SMTP服務(wù)器的用戶帳號
$smtppass = "hjl7233163"; //SMTP服務(wù)器的用戶密碼
$smtp = new Smtp($smtpserver, $smtpserverport, true, $smtpuser, $smtppass); //這里面的一個true是表示使用身份驗(yàn)證,否則不使用身份驗(yàn)證.
$emailtype = "HTML"; //信件類型,文本:text;網(wǎng)頁:HTML
$smtpemailto = $email;
$smtpemailfrom = $smtpusermail;
$emailsubject = "用戶帳號激活";
$emailbody = "親愛的" . $username . ":<br/>感謝您在我站注冊了新帳號。<br/>請點(diǎn)擊鏈接激活您的帳號。<br/><a href='http://www.dhdzp.com/demo/active.php?verify=" . $token . "' target='_blank'>http://www.dhdzp.com/demo/active.php?verify=" . $token . "</a><br/>如果以上鏈接無法點(diǎn)擊,請將它復(fù)制到你的瀏覽器地址欄中進(jìn)入訪問,該鏈接24小時(shí)內(nèi)有效。<br/>如果此次激活請求非你本人所發(fā),請忽略本郵件。<br/><p style='text-align:right'>-------- 腳本之家http://www.dhdzp.com敬上</p>";
$rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype);
if ($rs == 1) {
$msg = '恭喜您,注冊成功!<br/>請登錄到您的郵箱及時(shí)激活您的帳號!';
} else {
$msg = $rs;
}
echo $msg;
}
active.php
active.php接收提交的鏈接信息,獲取參數(shù)verify的值,即激活識別碼。將它與數(shù)據(jù)表中的用戶信息進(jìn)行查詢對比,如果有相應(yīng)的數(shù)據(jù)集,判斷是否過期,如果在有效期內(nèi)則將對應(yīng)的用戶表中字段status設(shè)置1,即已激活,這樣就完成了激活功能。
include_once("connect.php");//連接數(shù)據(jù)庫
$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 = '您的激活有效期已過,請登錄您的帳號重新發(fā)送激活郵件.';
}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;
激活成功后,發(fā)現(xiàn)token字段并沒有用處了,您可以清空。并且status激活狀態(tài)變?yōu)?了。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+mysql數(shù)據(jù)庫操作入門教程》、《php+mysqli數(shù)據(jù)庫程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP進(jìn)行批量任務(wù)處理不超時(shí)的解決方法
這篇文章主要介紹了PHP進(jìn)行批量任務(wù)處理不超時(shí)的解決方法,結(jié)合實(shí)例形式簡單分析了php結(jié)合ajax進(jìn)行異步處理實(shí)現(xiàn)批量任務(wù)不超時(shí)的相關(guān)技巧,需要的朋友可以參考下2016-07-07
PHP實(shí)現(xiàn)多圖上傳(結(jié)合uploadify插件)思路分析
這篇文章主要介紹了PHP實(shí)現(xiàn)多圖上傳的方法,實(shí)例分析了php結(jié)合uploadify插件實(shí)現(xiàn)多圖上傳的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2016-11-11
PHP計(jì)算字符串真正的寬度和高度像素(圖片加文字水印示例)
這篇文章通過給圖片加文字水印示例來解釋PHP計(jì)算字符串真正的寬度和高度像素的方法。計(jì)算字符串用strlen()只能得到字符串長度,不是寬高像素,而根據(jù)字體的大小和所用字體計(jì)算出的才是字符串真正的寬高像素。2023-02-02
php中print(),print_r(),echo()的區(qū)別詳解
本文介紹了php函數(shù)print(),print_r(),echo()的區(qū)別,這里推薦給大家,需要的朋友可以參考下2014-12-12
thinkphp中連接oracle時(shí)封裝方法無法用的解決辦法
本篇文章是對thinkphp中連接oracle時(shí)封裝方法無法用的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06

