DEDECMS文章模型整合下载功能,可判断点数,会员组等下载权限

DEDECMS文章模型整合下载功能,可判断点数,会员组等下载权限,第1张

概述本教程实现DEDECMS功能:文章模型整合下载功能,可判断点数,会员组等下载权限,前台可判断是否有附件下载,有则显示,没有则不显示。适用类型:有些文章有下载地址,有些文章没有下载地址的网站。想附件收费的网站等等……具体就不啰嗦了。用得上您就拿走。

本教程实现Dedecms功能:文章模型整合下载功能,可判断点数,会员组等下载权限,前台可判断是否有附件下载,有则显示,没有则不显示。适用类型:有些文章有下载地址,有些文章没有下载地址的网站。想附件收费的网站等等……具体就不啰嗦了。用得上您就拿走。

后台效果图

本教程为站长似水星辰原创,转载注明出处。

注:本教程中的金币和会员组设置只针对下载连接有效。不对文章内容生效,和文章本身的阅读权限和消费金币并不冲突,是分开设置的。文章中所有SQL语句中涉及表名的,请把表前缀换成您自己的表前缀。如:Js_addonarticle 换成 您的表前缀_addonarticle。

一、首先规划要加入的字段

下载链接:softlinks

消费金币:needmoney

会员组权限:daccess

这些字段要加入到文章附加表中,前缀_addonarticle,也可以根据自己情况加入需要的表中,自己修改就行了。

进入后台系统-sql命令行工具,执行:

ALTER table  `Js_addonarticle` ADD  `softlinks` TEXT NOT NulL ,  ADD  `needmoney` SMALliNT( 5 ) NOT NulL ,  ADD  `daccess` SMALliNT( 5 ) NOT NulL 

也可以在phpmyadmin中自行添加。

然后在后台打开核心-频道模型-内容模型管理-普通文章-修改-字段管理,在模型字段配置(文本模式) 里添加

   

如果不添加则会出现无链接信息错误!请务必添加。

二、数据库字段添加完毕就要修改文章模型的4个文件了。分别是dede管理目录下的article_add.PHP,article_edit.PHP和管理模板article_add.htm,article_edit.htm,打开这4个文件依次修改。

1、修改article_add.htm,在头部的中加入以下,在之前加入就行

var startNum = 0;  function MakeUpload()  {      var upfIEld = document.getElementByID("uploadfIEld");      var endNum =  parseInt(document.form1.picnum.value) + startNum-1;      if(endNum > 30) endNum = 30;      for(startNum; startNum<=endNum; startNum++){          upfIEld.INNERHTML += "软件地址"+startNum+":  服务器名称:\r\n";      }  }  function ShowHIDeAddr()  {      document.getElementByID('morelink').style.display = (document.getElementByID('morelink').style.display=='block' ? 'none' : 'block');      document.getElementByID('morelink').style.height = '100%';      document.getElementByID('btsh3').value = (document.getElementByID('morelink').style.display=='block' ? '隐藏地址' : '显示地址');  } 

这个是可以增加下载地址个数的JS代码

2、找到

再其后边加入

Setquery("Select * from `Js_arcrank` where rank>=0 ");                  $dsql->Execute();                  while($row = $dsql->GetArray())                  {                      if($row['rank']==0) $row['membername'] = "不限会员";                                      if($row['rank'] == $softconfig['dfrank']) echo "     {$row['membername']}\r\n";                                      else echo "     {$row['membername']}\r\n";                  }               ?>                            个          ]中“附件下载方式:”必须选择“链接到跳转页面”)                                 服务器名称:                                    ])            :      ' value='1' />      ' style='wIDth:200px' value='' /> +      ' style='wIDth:120px' value='' />          ' style='wIDth:150px' value='' />          ' class='np' value='1' checked />启用                                                                  &nbsp;                                (最多为30个链接)               到这里article_add.htm文件就修改完了。

3、打开article_edit.htm文件,在头部的中加入以下代码,在之前加入就行

var startNum = ;  function MakeUpload()  {      var upfIEld = document.getElementByID('uploadfIEld');      var endNum =  parseInt(document.form1.picnum.value) + startNum;      if(endNum > 30) endNum = 30;      for(startNum; startNum < endNum; startNum++)      {          upfIEld.INNERHTML += "软件地址"+startNum+":  服务器名称:\r\n";      }  }    function ShowHIDeAddr()  {      document.getElementByID('morelink').style.display = (document.getElementByID('morelink').style.display=='block' ? 'none' : 'block');      document.getElementByID('btsh3').value = (document.getElementByID('morelink').style.display=='block' ? '隐藏地址' : '显示地址');  } 

4、找到

在其下边加入以下代码:

Setquery("Select * from `Js_arcrank` where rank>=0 ");                  $dsql->Execute();                  while($row = $dsql->GetArray())                  {                      if($row['rank']==0) $row['membername'] = "不限会员";                                      if($row['rank'] == $daccess) echo "     {$row['membername']}\r\n";                                      else echo "     {$row['membername']}\r\n";                  }               ?>                               个             中“附件下载方式:”必须选择“链接到跳转页面”)                                   &nbsp;                                  (最多为30个链接)                                                                     article_edit.HTML修改完毕,接下来开始修改article_add.PHP,要认真看哦!

5、打开article_add.PHP,找到

//保存到附加表      $cts = $dsql->Getone("SELECT addtable FROM `Js_channeltype` WHERE ID='$channelID' "); 

在其上边加入

//软件链接列表      $urls = '';        //本地链接处理      $softurl1 = stripslashes($softurl1);      $nsoftsize = '';      if($softurl1 != '')      {          $urls .= "{dede:link islocal='1' text='{$servermsg1}'} $softurl1 {/dede:link}\r\n";      }        //其它链接处理      for($i=2; $i<=30; $i++)      {          if(!(${'softurl'.$i}))          {              $forconfig = (${'forconfig'.$i}) ? FALSE : TRUE;              if($forconfig)              {                  if(empty(${'need'.$i})) continue;                  $serverUrl = stripslashes(${'softurlfirst'.$i});                  $serverUrl = preg_replace("#\/$#", "", $serverUrl);                  $softurl = stripslashes(${'softurl'.$i});                  if( cn_substr($softurl, 1) != '/' ) $softurl = '/'.$softurl;                  $softurl = $serverUrl.$softurl;              }              else              {                  $softurl = stripslashes(${'softurl'.$i});              }              $servermsg = str_replace("'", stripslashes(${'servermsg'.$i}));              if($servermsg=='') $servermsg = '下载地址'.$i;              if($softurl != 'http://')              {                  $urls .= "{dede:link text='$servermsg'} $softurl {/dede:link}\r\n";              }          }      }      $urls = addslashes($urls); 

这段大概在203行左右,主要作用是处理下载地址。然后再找到

$query = "INSERT INTO `{$addtable}`(aID,typeID,redirecturl,templet,userip,body{$inadd_f}) Values('$arcID','$typeID','$redirecturl','$templet','$useip','$body'{$inadd_v})"; 

替换为

$query = "INSERT INTO `{$addtable}`(aID,body,softlinks,needmoney,daccess{$inadd_f}) Values('$arcID','$body','$urls','$needmoney','$daccess'{$inadd_v})"; 

article_add.PHP修改完毕,添加一下文章,把下载地址,金币,会员组都写进去,看看数据库是不是有这条记录了^ ^。

6、打开article_edit.PHP,找到

$channelID = $arcRow['channel']; 

在其上边加入

$newRowStart = 1;      $nForm = '';      $daccess = $addRow['daccess'];      $needmoney = $addRow['needmoney'];      if($addRow['softlinks'] != '')      {          $dtp = new DedeTagParse();          $dtp->LoadSource($addRow['softlinks']);          if(is_array($dtp->CTags))          {              foreach($dtp->CTags as $ctag)              {                  if($ctag->Getname()=='link')                  {                      $islocal = $ctag->GetAtt('islocal');                      if($islocal != 1) $needmsg = "删除";                      else $needmsg = '';                      $nForm .= "软件地址{$newRowStart}:GetInnerText())."' />              服务器名称:GetAtt("text")."' style='wIDth:150px' />                            $needmsg              \r\n";                      $newRowStart++;                  }              }          }          $dtp->Clear();      } 

找到

$cts = $dsql->Getone("SELECT addtable FROM `Js_channeltype` WHERE ID='$channelID' "); 

在其上边加入以下代码:

//软件链接列表      $urls = '';            for($i=1; $i<=30; $i++)      {          if(!empty(${'softurl'.$i}))          {              $islocal = empty(${'islocal'.$i}) ? '' : 1;              $isneed = empty(${'del'.$i}) ? true : false;              $servermsg = str_replace("'",'',stripslashes(${'servermsg'.$i}));              $softurl = stripslashes(${'softurl'.$i});                            if($servermsg=='')              {                  $servermsg = '下载地址'.$i;              }              if($softurl != 'http://')              {                  if($islocal==1) $urls .= "{dede:link islocal='$islocal' text='{$servermsg}'} $softurl {/dede:link}\r\n" ;                  else if($isneed) $urls .= "{dede:link text='$servermsg'} $softurl {/dede:link}\r\n";                  else continue;              }          }      }      $urls = addslashes($urls); 

找到

$iquery = "UPDATE `$addtable` SET typeID='$typeID',body='$body'{$inadd_f},redirecturl='$redirecturl',templet='$templet',userip='$useip' WHERE aID='$ID'"; 

替换为:

$iquery = "UPDATE `$addtable` SET typeID='$typeID',userip='$useip',softlinks ='$urls',needmoney = '$needmoney',daccess = '$daccess' WHERE aID='$ID'"; 

至此本教程后台修改部分已经完毕,你学会了吗?接下来开始前台部分。

三、前台调用,和软件的前台调用方式一样,看以下代码

{dede:fIEld name='softlinks'/} 

这个就是调用下载地址,打开的页面为软件模型的下载页,在哪里可以判断到下载的权限。这里就不多讲了,改完后就可以看到了。

有一种情况,就是有些网友希望没有下载地址的话就不显示,这里可以提供一种方法。把如下代码复制到文章模板里即可。

{dede:PHP}          $thisID = $refObj->FIElds['aID'];           $totrow=$dsql->Getone('select * from Js_addonarticle where aID='.$thisID);          if($totrow['softlinks']!='')          {          echo "href=\"/plus/download.PHP?open=0&aID=".$thisID."&cID=1\" style=\"color:white\" target=\"_blank\">下载地址";          }  {/dede:PHP} 

前台效果图

到这里,本教程全文完毕。

总结

以上是内存溢出为你收集整理的DEDECMS文章模型整合下载功能,可判断点数,会员组等下载权限全部内容,希望文章能够帮你解决DEDECMS文章模型整合下载功能,可判断点数,会员组等下载权限所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/zz/1013893.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存