首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在时间范围内查找数组中的记录

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

Stack Overflow用户
提问于 2013-05-14 03:40:03
回答 1查看 43关注 0票数 0

我在我的注册脚本中添加了一些帐户垃圾邮件安全措施。

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

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

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

代码语言:javascript
复制
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);
    }
}
EN

回答 1

Stack Overflow用户

发布于 2013-05-14 08:46:09

试试这个:

代码语言:javascript
复制
$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';

在members表中应该有一个名为'lastregistration‘的列,您现在可以将注册的时间存储在Unix时间戳中。

(您应该检查mysql服务器的时间和you服务器的时间。并且您应该使用mysqli_query()而不是mysql_query() ... )

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16529840

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档