首页 > CMS > 织梦DEDE > 正文

DEDECMS限制织梦会员每天投稿数量

2024-07-12 08:43:30
字体:
来源:转载
供稿:网友

有些网站加了投稿功能了,但会员可以无数投稿了,如果我们希望限制一个会员每天的投稿数量就可以参考下面方法来解决了。

我自己就写了这段代码,在我本地上测试成功,群里人也反映可以用,就把这段代码分享给大家,有需要的不妨试一试

第一步:打开member/article_add.php文件

第二步:在大约39行处找到以下代码

else if($dopost=="save")
{

第三步:在 { 中添加以下代码:

  1. $memberarcnum = $dsql->GetOne("SELECT count(*) FROM `dede_archives` WHERE mid='".$cfg_ml->M_ID."' AND FROM_UNIXTIME(senddate,'%Y-%m-%d') = curdate()"); 
  2. //判断当前投稿数量是否大于3篇 
  3. if($memberarcnum['count(*)'] > 3) 
  4. //Vevb.com 
  5.     ShowMsg("对不起,您所在会员组每日只可投稿3篇!","/member/content_list.php?channelid=1"); 
  6.     exit(); 

$memberarcnum['count(*)'] > 3,3这个数字可以任意修改,就是限制会员每天只可以发布3条.

方法二,近积分进行限制,如200积分以下的不能发稿,配置如了.

1.投稿:打开member/article_add.php,找到:

  1. if(emptyempty($dopost))  

在他后边加入:

  1. //检查用户  
  2. $username = $cfg_ml->M_UserName;  
  3. $l_jifen=$dsql->GetOne("Select scores from `js_member` where uname='$username'");  
  4. if($l_jifen['scores']>=200)  
  5. {  
  6. $dsql->ExecuteNoneQuery("Update `js_member` set logintime='".time()."',loginip='".GetIP()."' where mid='{$cfg_ml->M_ID}'; ");  
  7. }  //Vevb.com 
  8. else   
  9. {   
  10. ResetVdValue();   
  11. ShowMsg("对不起,需要200以上积分才能在发布文档!","-1","0",3000);  
  12. exit();   

2.评论:打开plus/feedback_ajax.php,找到:

  1.     //检查用户  
  2.         $username = emptyempty($username) ? '游客' : $username;  
  3.         if(emptyempty($notuser)) $notuser = 0;  
  4.         if($notuser==1)  
  5.         {  
  6.             $username = $cfg_ml->M_ID > 0 ? '匿名' : '游客';  
  7.         }  
  8.         else if($cfg_ml->M_ID > 0)  
  9.         {  
  10.             $username = $cfg_ml->M_UserName;  
  11.         }  
  12.         else if($username!='' && $pwd!='')  
  13.         {  
  14.             $rs = $cfg_ml->CheckUser($username$pwd);  
  15.             if($rs==1)  
  16.             {  
  17.                 $dsql->ExecuteNoneQuery("Update `js_member` set logintime='".time()."',loginip='".GetIP()."' where mid='{$cfg_ml->M_ID}'; ");  
  18.             }  
  19.             $cfg_ml = new MemberLogin();  
  20.         } 
  21. //替换为: 
  22.     //检查用户  
  23.     $username = $cfg_ml->M_UserName;  
  24.     $l_jifen=$dsql->GetOne("Select scores from `js_member` where uname='$username'");  
  25.     if($l_jifen['scores']>=150)  
  26.     {  
  27.     $dsql->ExecuteNoneQuery("Update `js_member` set logintime='".time()."',loginip='".GetIP()."' where mid='{$cfg_ml->M_ID}'; ");  
  28.     }  
  29.     else   
  30.     {   
  31.     ResetVdValue();   
  32.     ShowMsg("对不起,需要150以上积分才能在发布文档!","-1","0",3000);  
  33.     exit();   
  34.     } 

这样就可以有效的判断了,其余模型的修改也类似这样的.

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表