首頁 >後端開發 >php教程 >php如何實現使用者信箱註冊啟動代碼詳解

php如何實現使用者信箱註冊啟動代碼詳解

伊谢尔伦
伊谢尔伦原創
2017-07-15 13:23:045958瀏覽

使用者在網站進行登入註冊的時候,通常需要使用使用者的自有郵箱,郵箱收到網站郵件進行帳號的激活,然後才能正常使用。  本文將結合實例介紹如何使用PHP+Mysql完成註冊帳號、傳送啟動郵件、驗證啟動帳號、處理URL連結過期的功能。收到一封含點擊連結啟動的郵件來進行啟動。

註冊郵箱啟動流程

1、用戶註冊
2、插入用戶數據,此時帳號未啟動狀態。
3、將使用者名稱密碼或其他識別字元加密建構成啟動識別碼(你也可以叫啟動碼)。
4、將建構好的啟動識別碼組成URL傳送到使用者提交的郵箱。
5、使用者登入郵箱並點選URL,進行啟動。
6、驗證啟動識別碼,如果正確則啟動帳號。

建立資料庫表格

#我們在註冊帳戶時,一般在使用者表中會記錄下我們的id、使用者名稱、密碼、信箱或手機號,還會有一個帳號啟動與否的欄位。

使用者資訊表中欄位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>

register.php完成寫入資料和發送郵件

#首先連接資料庫 和包含郵件發送類別smtp .class.php

include_once("connect.php");//连接数据库
include_once("smtp.class.php");//邮件发送类

前端驗證表單我們省略了,直接看程式

$username = stripslashes(trim($_POST[&#39;username&#39;]));
$query = mysql_query("select id from t_user where username=&#39;$username&#39;");
$num = mysql_num_rows($query);
if($num==1){
  echo &#39;用户名已存在,请换个其他的用户名&#39;;
  exit;
}

接著我們將使用者密碼加密,建構啟動識別碼:

$password = md5(trim($_POST[&#39;password&#39;])); //加密密码
$email = trim($_POST[&#39;email&#39;]); //邮箱
$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 (&#39;$username&#39;,&#39;$password&#39;,&#39;$email&#39;,&#39;$token&#39;,&#39;$token_exptime&#39;,&#39;$regtime&#39;)";
mysql_query($sql);

上述程式碼中,$token即構造好的啟動識別碼,它是由使用者名稱、密碼和當前時間組成並md5加密得來的。 $token_exptime用於設定啟動連結URL的過期時間,使用者在這個時間段內可以啟動帳號,本例設定的是24小時內啟動有效。最後將這些欄位插入到資料表t_user中。

當資料插入成功後,呼叫郵件發送類別將啟動資訊傳送給使用者註冊的郵箱,注意將構造好的啟動識別碼組成一個完整的URL作為使用者點擊時的啟動鏈接,以下是詳細代碼:

if (mysql_insert_id()) {//写入成功,发邮件
  include_once("smtp.class.php");
  $smtpserver = "smtp.163.com"; //SMTP服务器
  $smtpserverport = 25; //SMTP服务器端口
  $smtpusermail = "hjl416148489_4@163.com"; //SMTP服务器的用户邮箱
  $smtpuser = "hjl416148489_4@163.com"; //SMTP服务器的用户帐号
  $smtppass = "hjl7233163"; //SMTP服务器的用户密码
  $smtp = new Smtp($smtpserver, $smtpserverport, true, $smtpuser, $smtppass); //这里面的一个true是表示使用身份验证,否则不使用身份验证.
  $emailtype = "HTML"; //信件类型,文本:text;网页:HTML
  $smtpemailto = $email;
  $smtpemailfrom = $smtpusermail;
  $emailsubject = "用户帐号激活";
  $emailbody = "亲爱的" . $username . ":<br/>感谢您在我站注册了新帐号。<br/>请点击链接激活您的帐号。<br/>
  <a href=&#39;http://www.php.cn/demo/active.php?verify=" . $token . "&#39; target=&#39;_blank&#39;>http://www.php.cn/demo/active.php?verify=" . $token . "</a>
  <br/>如果以上链接无法点击,请将它复制到你的浏览器地址栏中进入访问,该链接24小时内有效。<br/>如果此次激活请求非你本人所发,请忽略本邮件。<br/>
  ";
  $rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype);
  if ($rs == 1) {
    $msg = &#39;恭喜您,注册成功!<br/>请登录到您的邮箱及时激活您的帐号!&#39;;
  } else {
    $msg = $rs;
  }
  echo $msg;
}

active.php

#active.php接收提交的連結訊息,取得參數verify的值,即啟動識別碼。將它與數據表中的用戶資訊進行查詢對比,如果有相應的數據集,判斷是否過期,如果在有效期內則將對應的用戶表中字段status設置1,即已激活,這樣就完成了激活功能。

$email使我們註冊時的郵箱,我們用urlencode()來編碼一下,將字串用於URL 的請求部分,$activation_key就是我們產生的啟動碼了,我們用伺服器向這個email發送啟動郵件,而這個在郵箱客戶端裡,會顯示成一個超鏈接,提示你點擊,點擊後,我們就把email和key傳送到了activate.php文件,也就是開始執行驗證並激活帳戶了。

include_once("connect.php");//连接数据库
$verify = stripslashes(trim($_GET[&#39;verify&#39;]));
$nowtime = time();
$query = mysql_query("select id,token_exptime from t_user where status=&#39;0&#39; and
`token`=&#39;$verify&#39;");
$row = mysql_fetch_array($query);
if($row){
  if($nowtime>$row[&#39;token_exptime&#39;]){ //24hour
    $msg = &#39;您的激活有效期已过,请登录您的帐号重新发送激活邮件.&#39;;
  }else{
    mysql_query("update t_user set status=1 where id=".$row[&#39;id&#39;]);
    if(mysql_affected_rows($link)!=1) die(0);
    $msg = &#39;激活成功!&#39;;
  }
}else{
  $msg = &#39;error.&#39;;
}
echo $msg;

啟動成功後,發現token欄位並沒有用處了,您可以清空。並且status激活狀態變成1了。 現在帳號就啟動了,使用者在登入時,先配對activation是否為activated,接著再進行後續步驟。

以上是php如何實現使用者信箱註冊啟動代碼詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn