我們在註冊一個網站的帳戶時,通常都會收到一封包含點擊連結啟動的郵件,本篇文章主要介紹了PHP郵件激活帳戶的實現代碼,有興趣的可以了解一下
#我們在註冊一個網站的帳戶時,通常都會收到一封含點擊連結啟動的郵件,而它是怎麼激活我們的帳戶的呢,今天向大家介紹一種方法。
預備條件
我們在註冊帳戶時,一般在用戶表中會記錄下我們的id、用戶名、密碼、郵箱或手機號,還會有一個帳戶啟動與否的欄位。我們假設它為activation varchar(50)
註冊時一般都會產生一個激活碼,並且把激活碼插入activation字段,我們可以使用$activation_key=bin2hex(openssl_random_pseudo_bytes(16));
來生成,並且把它插入欄位。
在連結中儲存啟動訊息
既然我們點擊了郵件裡的連結後,就啟動了帳戶,那麼說明這個連結裡,必然儲存了啟動訊息。而它該儲存哪些資訊呢,首先,必須有啟動碼,還有用戶註冊時的郵箱或id,我們這裡用郵箱。例如下面這個連結。
複製程式碼 程式碼如下:
#$message.="57237ff8d72be4b8a5d9f4ba9a4a075aActivate5db79b134e9f6b82c0b36e0489ee08ed";
$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['email'])||!isset($_GET["key"])){ echo "<p class='alert alert-danger'>Account Activation Failed</p>"; exit;//如果邮件链接损坏,没有传入用户激活信息,则不执行后续步骤 } $email=$_GET['email']; $key=$_GET['key']; $email=mysqli_real_escape_string($link, $email); $key=mysqli_real_escape_string($link, $key);//转义特殊字符 $sql="UPDATE users SET activation='activated' WHERE (user_email='$email' AND activation='$key') LIMIT 1"; $result=mysqli_query($link, $sql);//查询email与key匹配的数据项,并且更新activation字段到activated if (mysqli_affected_rows($link)==1){ echo "<p>Account Activated</p>"; echo '<a href="index.php" rel="external nofollow" type="button">Login</a>'; echo "<br/>"; }else{ echo "<p>Account Activation Failed Or Already Activated</p>"; } ?>
現在帳戶就啟動了,用戶在登入時,先配對activation是否為activated,接著再進行後續步驟
此文僅只涉及這個問題的解決方法,一個完整的用戶註冊、啟動、登錄,也應該配置發送郵件的伺服器
相關推薦:
以上是PHP實作使用者註冊郵件啟動帳號的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!