帝国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') ,判断是否超数量下载。
|