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

Php 在时间范围内查找数组中的记录,php,mysql,ip,timestamp,registration,Php,Mysql,Ip,Timestamp,Registration,我正在注册脚本中添加一些帐户垃圾邮件安全性 脚本的目的是,如果数据库中有10个以上的帐户与其IP地址匹配,并且这10个帐户是在最后一个小时内创建的,那么脚本将拒绝用户创建新帐户 例如,这将允许图书馆中的人创建他们的帐户,同时也防止人们在我们的数据库中滥发帐户 我有以下代码,但如何检查在过去1小时内是否有10个或更多帐户 if($count_existscheck==1) { echo 'account already exists.'; exit(); } if($count_e

我正在注册脚本中添加一些帐户垃圾邮件安全性

脚本的目的是,如果数据库中有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';
您应该在tha members表中有一个名为“lastregistration”的列,在该列中,您现在将注册时间存储在Unix时间戳中


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

你想检查IP吗?这不是一个非常可靠的检查重复帐户(或10个帐户,在您的情况下)的方法