详情页

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

时间:2024年03月28日

编辑:佚名

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') ,判断是否超数量下载。
相关文章
猜你需要