如何在输入数据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预定事件?
答案 0 :(得分:2)
不要使用1或0进行阻止,而是使用时间戳。当用户尝试登录时,检查当前时间并将其与数据库中的时间戳进行比较
答案 1 :(得分:1)
不是手动重置计数,而是在表格中添加一个时间戳列,指示上次尝试的时间。
当检测到无效尝试时,将当前时间与记录的时间进行比较: