如何在执行另一个 SQL 查询后 x 分钟执行另一个查询


How to perform an SQL query x minutes after another one is executed?

如何

使放入数据库的信息在输入数据 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 表示阻止,而是使用时间戳。当用户尝试登录时,请检查当前时间并将其与数据库中的时间戳进行比较

不要手动重置计数,而是在表中添加一个时间戳列,指示上次尝试的时间。

检测到无效尝试时,将当前时间与记录的时间进行比较:

  • 如果超过 5 分钟,则重置计数。
  • 如果

  • 不到 5 分钟,则在低于阈值时增加计数,如果超过阈值,则阻止尝试。