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

时间:2015-01-30 12:36:38

标签: php database mysqli

如何在输入数据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预定事件?

2 个答案:

答案 0 :(得分:2)

不要使用1或0进行阻止,而是使用时间戳。当用户尝试登录时,检查当前时间并将其与数据库中的时间戳进行比较

答案 1 :(得分:1)

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

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

  • 如果if超过5分钟,则重置计数。
  • 如果小于5分钟,如果小于阈值则递增计数,或者如果超过阈值则阻止尝试。