PHP用戶註冊郵件啟動帳號的功能

怪我咯
發布: 2023-03-10 14:52:01
原創
1465 人瀏覽過

我們在註冊一個網站的帳戶時,通常都會收到一封包含點擊連結啟動的郵件,本篇文章主要介紹了PHP郵件激活帳戶的實現代碼,有興趣的可以了解一下

#我們在註冊一個網站的帳戶時,通常都會收到一封含點擊連結啟動的郵件,而它是怎麼激活我們的帳戶的呢,今天向大家介紹一種方法。

預備條件

我們在註冊帳戶時,一般在用戶表中會記錄下我們的id、用戶名、密碼、郵箱或手機號,還會有一個帳戶啟動與否的欄位。我們假設它為activation varchar(50) 註冊時一般都會產生一個激活碼,並且把激活碼插入activation字段,我們可以使用$activation_key=bin2hex(openssl_random_pseudo_bytes(16)); 來生成,並且把它插入欄位。

在連結中儲存啟動訊息

既然我們點擊了郵件裡的連結後,就啟動了帳戶,那麼說明這個連結裡,必然儲存了啟動訊息。而它該儲存哪些資訊呢,首先,必須有啟動碼,還有用戶註冊時的郵箱或id,我們這裡用郵箱。例如下面這個連結。


複製程式碼 程式碼如下:


#$message.="Activate";

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

在activate.php中驗證訊息

我們使用URL請求向activate.php傳入使用者信箱和啟動碼,現在只需要調取資料庫中原有的資訊進行對比,就可以驗證使用者了,所以我們第一步才將啟動碼插入使用者表中,我寫了一個activate.php的範例:


<?php
$link=mysqli_connect("localhost", "root", "root", "project") or die("Database Access Denied");//连接数据库
if (!isset($_GET[&#39;email&#39;])||!isset($_GET["key"])){
  echo "<p class=&#39;alert alert-danger&#39;>Account Activation Failed</p>";
  exit;//如果邮件链接损坏,没有传入用户激活信息,则不执行后续步骤
}
$email=$_GET[&#39;email&#39;];
$key=$_GET[&#39;key&#39;];
$email=mysqli_real_escape_string($link, $email);
$key=mysqli_real_escape_string($link, $key);//转义特殊字符
$sql="UPDATE users SET activation=&#39;activated&#39; WHERE (user_email=&#39;$email&#39; AND activation=&#39;$key&#39;) LIMIT 1";
$result=mysqli_query($link, $sql);//查询email与key匹配的数据项,并且更新activation字段到activated
if (mysqli_affected_rows($link)==1){
  echo "<p>Account Activated</p>";
  echo &#39;<a href="index.php" rel="external nofollow" type="button">Login</a>&#39;;
  echo "<br/>";
}else{
  echo "<p>Account Activation Failed Or Already Activated</p>";
}
?>
登入後複製


現在帳戶就啟動了,用戶在登入時,先配對activation是否為activated,接著再進行後續步驟

此文僅只涉及這個問題的解決方法,一個完整的用戶註冊、啟動、登錄,也應該配置發送郵件的伺服器

以上是PHP用戶註冊郵件啟動帳號的功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板