【发布时间】:2014-01-01 10:15:02
【问题描述】:
我正在尝试使用 PHP 编写密码恢复脚本,在 SO 中查看这里之后,最佳实践的共识似乎是
- 生成过期令牌
- 通过电子邮件向用户发送令牌
- 用户点击令牌并更改密码。
我目前有生成令牌的功能,但我将如何使其过期?另外,令牌的良好保质期是多少?
令牌生成代码:
function crypto_rand_secure($min, $max) {
$range = $max - $min;
if ($range < 0) return $min; // not so random...
$log = log($range, 2);
$bytes = (int) ($log / 8) + 1; // length in bytes
$bits = (int) $log + 1; // length in bits
$filter = (int) (1 << $bits) - 1; // set all lower bits to 1
do {
$rnd = hexdec(bin2hex(openssl_random_pseudo_bytes($bytes)));
$rnd = $rnd & $filter; // discard irrelevant bits
} while ($rnd >= $range);
return $min + $rnd;
}
function GenerateToken($length){
$token = "";
$codeAlphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
$codeAlphabet.= "abcdefghijklmnopqrstuvwxyz";
$codeAlphabet.= "0123456789";
for($i=0;$i<$length;$i++){
$token .= $codeAlphabet[crypto_rand_secure(0,strlen($codeAlphabet))];
}
return $token;
}
P.s 上面的代码是从 S.O 上的另一个问题复制粘贴的
【问题讨论】: