新聞中心
## Redis安全激活碼

成都創(chuàng)新互聯堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網站設計、成都網站制作、企業(yè)官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯網時代的沾化網站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!
在網絡認證中,安全激活碼是一種特殊的登錄驗證方式,用戶需要先填寫自己的郵箱地址,然后系統(tǒng)會發(fā)送一封郵件,里面包含一串激活碼。用戶只有提交正確的激活碼,才能完成激活。
在用戶激活之前,我們需要把用戶提交的郵箱地址存儲起來,常見的存儲方式是使用關系型數據庫,但是大多數關系型數據庫(比如MySQL)的存儲過程比較繁瑣,效率也相對較低。此外,關系型數據庫也有一定的漏洞,不安全。
為了優(yōu)化存儲用戶郵箱地址的安全性和效率,我們可以使用Redis存儲用戶的郵箱地址,Undertow框架的Redis服務器提供了一個非常簡潔的API來實現這一功能。
### Redis服務搭建
我們需要先在服務器上(可以是電腦,云服務器)上搭建有Redis服務器,在CentOS 8上安裝Redis服務器的過程其實很簡單,只需要Playbook/Shell腳本就可以搞定。
接下來,在搭建好Redis服務器后,你就可以通過服務器訪問地址和端口號來通過客戶端連接服務器,比如redis-cli。
### 使用Redis存儲用戶郵箱
我們需要使用Redis中的SET命令,將用戶填寫的郵箱地址作為Key,設置一個隨機字符串作為Value,實現存儲用戶郵箱存取操作,代碼如下:
// 連接Redis服務器
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
// 獲取用戶郵箱
$eml = $_POST['eml'];
// 隨機生成6位激活碼
$activeCode = substr(uniqid(),0,6);
// 使用SET命令將用戶郵箱作為Key,激活碼作為Value存儲
$redis->set($eml, $activeCode);
### 發(fā)送郵件
在Redis服務器存儲了用戶郵箱和激活碼之后,再使用PHP發(fā)送郵件,把激活碼發(fā)送給用戶的郵箱,這樣用戶就可以收到安全的激活碼了,代碼如下:
// 獲取激活碼
$activeCode = $redis->get($eml);
// 郵箱配置信息
$from = '[email protected]';
$to = $eml;
$subject = '安全激活碼';
// 激活地址
$url = 'http://xxx.xxx.com/active.php?code='.$activeCode;
$body = '請點擊鏈接激活:'.$url;
// 發(fā)送郵件
$result = ml($to, $subject, $body);
if ($result) {
print_r("郵件發(fā)送成功!");
} else {
print_r("郵件發(fā)送失敗!")
}
### 驗證激活碼
接下來,當用戶收到郵件并點擊激活碼時,就可以開始進行激活碼的驗證了,我們可以使用Redis的Get命令,從Redis服務器中獲取到用戶之前存儲的激活碼,然后和用戶提交的激活碼進行比對,如果兩個激活碼一致,則認證通過,代碼實例如下:
// 獲取激活碼
$activeCode = $_GET['code'];
// 從Redis服務器獲取存儲的激活碼
$savedActiveCode = $redis->get($eml);
// 比對激活碼
if ($savedActiveCode == $activeCode) {
print_r("驗證通過!");
} else {
print_r("驗證失?。?);
}
相比傳統(tǒng)的用戶認證方式,使用Redis存儲用戶郵箱地址安全激
香港服務器選創(chuàng)新互聯,2H2G首月10元開通。
創(chuàng)新互聯(www.cdcxhl.com)互聯網服務提供商,擁有超過10年的服務器租用、服務器托管、云服務器、虛擬主機、網站系統(tǒng)開發(fā)經驗。專業(yè)提供云主機、虛擬主機、域名注冊、VPS主機、云服務器、香港云服務器、免備案服務器等。
當前標題:用Redis存儲用戶郵箱,實現安全激活(redis郵箱激活)
文章來源:http://fisionsoft.com.cn/article/dhhejoo.html


咨詢
建站咨詢
