如何
使放入数据库的信息在输入数据 5 分钟后自行更新?
假设我有一张桌子:
+--+--+-----+
|id|ip|count|
+--+--+-----+
| 1|..|3 |
+--+--+-----+
当计数大于 1 时,我想等待 5 分钟,然后将其改回 1。
我想要这个是因为我想在用户输入错误密码 3 次或更多次时设置"超时"!
因此,我为用户输入错误的密码编写了以下代码:
$currentIP = $_SERVER['REMOTE_ADDR'];
$ipcheck = mysqli_query($con,"SELECT *
FROM ipcheck");
while($row = mysqli_fetch_array($ipcheck))
{
if($currentIP == $row['ip']){
if($row['count'] > 2){
//attempted to log in too many times!
header("Location: secure?err=2");
exit;
}else{
$IPUsed = "YES";
}
}
}
if($IPUsed == "YES"){
//They have failed to log in AGAIN!
$updateIP = mysqli_query($con,"UPDATE ipcheck
SET count = count + 1
WHERE ip = '".$currentIP."'");
}else{
//first failed login attempt
$insertNewIp = mysqli_query($con,"INSERT INTO ipcheck (ip)
VALUES ('".$currentIP."')");
}
这创建了上面的表格,但是做我的问题的最佳方法是什么?会通过使用 cron 吗?或者也许是 MySQL 计划事件?
不要使用
1 或 0 表示阻止,而是使用时间戳。当用户尝试登录时,请检查当前时间并将其与数据库中的时间戳进行比较
不要手动重置计数,而是在表中添加一个时间戳列,指示上次尝试的时间。
检测到无效尝试时,将当前时间与记录的时间进行比较: