手工SEO

手工SEO首頁 DEDE教程 正文

織夢dedecms軟件頻道限制會員按天和按小時下載的方法

手工SEO 2020-06-05 10:20:38 DEDE教程 167℃ 手工SEO

在使用織夢cms建網站的時候,有時候為了較少服務器的壓力或者防止一些會員惡意下載,就需要對會員每天的下載次數做限制,那么如何實現這個功能呢?下面跟版網小編帶您一步步操作:

1、首先在后臺的數據庫備份/還原地方做一個數據庫備份,因為接下來要執行幾個sql文件,做好數據備份以免出現未知錯誤。

2、
建立dede_xiazai 這個數據庫表,執行以下sql:

CREATE TABLE `dede_xiazai` ( `mid` int(11) NOT NULL, `aid` int(11) NOT NULL, `mtime` int(11) NOT NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1;  

3、在原數據庫表dede_arcrank內增加兩個字段 daydowns hourdowns 分別為 每天限制次數 每日限制次數,在這里默認是10次,大家可以按照自己的需求更改這個次數:DEFAULT '10'

ALTER TABLE `dede_arcrank` ADD `daydowns` INT(6) NOT NULL DEFAULT '10' AFTER `purviews`, ADD `hourdowns` INT(6) NOT NULL DEFAULT '10' AFTER `daydowns`;  

4、找到plus文件夾下的download.php文件在191行插入:

//獲取用戶級別// $rank = $dsql->GetOne("SELECT rank FROM `dede_member` WHERE mid='" . $cfg_ml->M_ID . "'"); $level = $dsql->GetOne("SELECT membername,daydowns,hourdowns FROM `dede_arcrank` WHERE rank='" . $rank['rank'] . "'"); //查詢下載次數,限制下載次數// $row = $dsql->GetOne("SELECT COUNT(mid) FROM `dede_xiazai` WHERE mid='" . $cfg_ml->M_ID . "' AND to_days(curdate())=to_days(from_unixtime(mtime))"); $daycishu = $row['COUNT(mid)']; $date = date("Y-m-d H:00", time()); $hour = strtotime($date); $row2 = $dsql->GetOne("SELECT COUNT(mid) FROM `dede_xiazai` WHERE mid='" . $cfg_ml->M_ID . "' AND mtime >= '" . $hour . "'"); $hourcishu = $row2['COUNT(mid)']; if ($level['daydowns'] != 0) { if ($daycishu >= $level['daydowns']) { $errtype = 3; $moremsg = $level['membername'] . "24小時內最多能下載" . $level['daydowns'] . "個資源,您的下載次數已到達" . $daycishu . "次"; include_once (DEDETEMPLATE . '/plus/view_msg.htm'); exit(0); } } if ($level['hourdowns'] != 0) { if ($hourcishu >= $level['hourdowns']) { $errtype = 3; $moremsg = $level['membername'] . "1小時內最多能下載" . $level['hourdowns'] . "個資源,您的下載次數已到達" . $hourcishu . "次"; include_once (DEDETEMPLATE . '/plus/view_msg.htm'); exit(0); } } //用戶為注冊會員以上級別,做下載次數記錄//// if ($cfg_ml->M_Rank >= 10) { //下載次數記錄 $inquery = "INSERT INTO `dede_xiazai`(mid,mtime,aid) VALUES ('" . $cfg_ml->M_ID . "','" . time() . "','.$id.'); "; //記錄定單 if (!$dsql->ExecuteNoneQuery($inquery)) { ShowMsg('記錄定單失敗, 請返回', '-1'); exit(0); }  

上一篇:織夢channelartlist如何利用itemindex做判斷

下一篇:Dedecms欄目綁定二級域名RSS文件地址URL錯誤

網站分類
標簽列表
问道多少级队伍号赚钱 申城棋牌网? 急速赛车开奖app 股票入门知识软件 贵州十一选五前三直走势 安徽11选5开奖结果丨 微豪配资 安徽快三直播 _百家乐代理 什么号码是连码 腾讯qq麻将手机版官方下载 二分时时彩开奖记录 湖北快3专家预测豹子 江苏11选五数据遗漏 幸运农场玩法及奖金 百宝彩票青海快3 吉林11选5高手指点