在数组中查找时间范围内的记录


Find records in array in time range

我正在为我的注册脚本添加一些帐户垃圾邮件安全。

目的是让脚本拒绝用户创建新帐户,如果数据库中有超过10个帐户与他们的IP地址匹配,并且这10个帐户是在过去一小时内创建的。

例如,这将允许图书馆中的人们创建他们的帐户,同时也防止人们在我们的数据库中发送垃圾邮件帐户。

我有以下代码,但是我如何检查在过去1小时内是否有10个或更多的帐户?

if($count_existscheck==1) {
    echo 'account already exists.';
    exit();
}
if($count_existscheck==0) {
    // begin check for IPs
    $ip = $_SERVER['REMOTE_ADDR'];
    $sql_ipcheck = "SELECT * FROM members WHERE ip='$ip'";
    $result_ipcheck = mysql_query($sql_ipcheck);
    $count_ipcheck = mysql_num_rows($result_ipcheck);
    // if count =10 or >10, check if they were in the last hour
    if($count_ipcheck>9) {
        $row_ipcheck = mysql_fetch_assoc($result_ipcheck);
    }
}

试试这个:

$onehourbefore = strtotime('-1 hour');
$sql_ipcheck = "SELECT * FROM members 
         WHERE ip = '$ip' AND lastregistration > $onehourbefore;
$result_ipcheck = mysql_query($sql_ipcheck);
if(mysql_num_rows($result_ipcheck)>=10) echo 'Access Denied';

在成员表中应该有一个名为'lastregistration'的列,用于存储当前以Unix时间戳形式注册的时间。

(你应该检查你的mysql服务器的时间和你的web服务器的时间。你应该使用mysqli_query()而不是mysql_query()…