帝国CMS中会员每日下载数限制的实现

1.后台会员组设置,每日下载数

<input name="daydown" type="text" id="daydown" value="0" size="38">

2.缓存
在文件 e/data/dbcache/MemberLevel.php中有缓存,假定会员组id为$groupid
则该会员组的每日下载次数限制调用为

   $level_r[$groupid]['daydown'];
   
当然,调用的前提是引用了这个缓存文件,例如:
    include(ECMS_PATH."e/data/dbcache/MemberLevel.php");


3.检查下载次数
在文件  /e/class/user.php中,有个函数,用来检查下载次数

//检查下载数
function DoCheckMDownNum($userid,$groupid,$ecms=0){
    global $empire,$dbtbpre,$level_r;
    $ur=$empire->fetch1("select userid,todaydate,todaydown from {$dbtbpre}enewsmemberadd where userid='$userid' limit 1");
    $thetoday=date("Y-m-d");
    if($ur['userid'])
    {
        if($thetoday!=$ur['todaydate'])
        {
            $query="update {$dbtbpre}enewsmemberadd set todaydate='$thetoday',todaydown=1 where userid='$userid'";
        }
        else
        {
            if($ur['todaydown']>=$level_r[$groupid]['daydown'])
            {
                if($ecms==1)
                {
                    exit();
                }
                elseif($ecms==2)
                {
                    return 'error';
                }
                else
                {
                    printerror("CrossDaydown","history.go(-1)",1);
                }
            }
            $query="update {$dbtbpre}enewsmemberadd set todaydown=todaydown+1 where userid='$userid'";
        }
    }
    else
    {
        $query="replace into {$dbtbpre}enewsmemberadd(userid,todaydate,todaydown) values('$userid','$thetoday',1);";
    }
    return $query;
}



4. 检查的方法

if($level_r[$u[$user_group]][daydown])
        {
            $setuserday=DoCheckMDownNum($userid,$u[$user_group]);
        }
    随后, 更新下载次数
    
        //更新用户下载次数
        if($setuserday)
        {
            $usql=$empire->query($setuserday);
        }
        
        
        
5.体会
在二开的情况下,我们用DoCheckMDownNum($userid,$u[$user_group],2)更容易控制流程。
随后 if($setuserday=='error') ,判断是否超数量下载。

声明:有的资源均来自网络转载,版权归原作者所有,如有侵犯到您的权益 请联系邮箱:312334557@qq.com 我们将配合处理!

原文地址:《帝国cms二开之会员每日下载次数限制的实现》发布于2021-08-01 14:12:38