您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關PHP怎么實現用戶注冊郵件激活賬戶的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
預備條件
我們在注冊賬戶時,一般在用戶表中會記錄下我們的id、用戶名、密碼、郵箱或手機號,還會有一個賬戶激活與否的字段。我們假設它為 activation varchar(50)
注冊時一般都會生成一個激活碼,并且把激活碼插入activation字段,我們可以使用$activation_key=bin2hex(openssl_random_pseudo_bytes(16));
來生成,并且把它插入字段。
在鏈接中保存激活信息
既然我們點擊了郵件里的鏈接后,就激活了賬戶,那么說明這個鏈接里,必然儲存了激活信息。而它應該儲存哪些信息呢,首先,必須有激活碼,還有用戶注冊時的郵箱或者id,我們這里用郵箱。例如下面這個鏈接。
復制代碼 代碼如下:
$message.="<a href="." rel="external nofollow" http://www.XXXXX.com/activate.php?email=".urlencode($email)."&key=$activation_key".">Activate</a>";
$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 "<div class='alert alert-danger'>Account Activation Failed</div>"; 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 "<div>Account Activated</div>"; echo '<a href="index.php" rel="external nofollow" type="button">Login</a>'; echo "<br/>"; }else{ echo "<div>Account Activation Failed Or Already Activated</div>"; } ?>
現在賬戶就激活了,用戶在登錄時,先匹配一下activation是否為activated,接著再進行后續步驟
此文僅僅只涉及這個問題的解決方法,一個完整的用戶注冊、激活、登錄,還應該配置發送郵件的服務器
感謝各位的閱讀!關于“PHP怎么實現用戶注冊郵件激活賬戶”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。