首页 > CMS > 织梦DEDE > 正文

DEDECMS文章模型整合下载功能实例

2024-07-12 08:47:38
字体:
来源:转载
供稿:网友
这篇文章主要为大家详细介绍了DEDECMS文章模型整合下载功能实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,有需要的朋友可以收藏方便以后借鉴。

最近帮朋友仿一个站点,用的是织梦dedecms,在访到文章内容的时候,发现文章内容里有不少的下载功能连接。织梦的文章模型是不带下载功能的,有的只有附件等辅助功能,一般不怎么够用。下面是361源码网在网上整理收集到的关于DEDECMS文章模型整合下载功能实例教程,分享给大家。

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

下载链接: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中自行添加。

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

<field:softlinks  itemname="软件地址" type="softlinks" isnull="true" default="" rename="" /> <field:daccess islist="1" itemname="下载级别" type="int" isnull="true" default="0" rename="" function="" notsend="1"/>   <field:needmoney islist="1" itemname="需要金币" type="int" isnull="true" default="0" rename="" function="" notsend="1" />

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

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

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 += "<div style='line-height:36px'>软件地址"+startNum+":<input type='text' name='softurl"+startNum+"' style='width:280px' value='http://' />  服务器名称:<input type='text' name='servermsg"+startNum+"' style='width:150px' /></div>/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' ? '隐藏地址' : '显示地址'); }


2、找到

<tr>      <td colspan="2"><?php PrintAutoFieldsAdd($cInfos['fieldset'],'autofield'); ?></td>    </tr>

再其后边加入

<tr>       <td height="24" bgcolor="#F9FCEF"" class="bline2"><strong>&nbsp;下载限制:</strong></td>     </tr>     <tr>       <td height="24"  class="bline">       <table width="800" border="0" cellpadding="0" cellspacing="0">         <tr>           <td width="90" height="30">&nbsp;需会员权限:</td>           <td width="179" align="left">               <select name="daccess" id="daccess" style="width:90px">                 <?php                 $dsql->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 "     <option value='{$row['rank']}' selected>{$row['membername']}</option>/r/n";                                     else echo "     <option value='{$row['rank']}'>{$row['membername']}</option>/r/n";                 }              ?>                 </select>          </td>           <td width="120" align="center">需消费金币:</td>           <td width="411">             <input name="needmoney" type="text" id="needmoney" value="<?php echo $softconfig['dfywboy']; ?>" size="8" />个          </td>         </tr>             <tr>               <td height="26" colspan="4" style="border-top:1px dashed #8EAF61">&nbsp; <span class="STYLE1">(如果设定了下载限制,[<a href="soft_config.php" target="_blank"><u>软件频道设置</u></a>]中“附件下载方式:”必须选择“链接到跳转页面”) </span></td>           </tr>       </table>       </td>     </tr>     <tr>       <td height="24" bgcolor="#F9FCEF" class="bline2"><strong>&nbsp;本地软件选择:</strong></td>     </tr>     <tr>       <td height="24"  class="bline">       <table width="800" border="0" cellspacing="0" cellpadding="0">           <tr>             <td width="90" height="30">&nbsp;本地地址:</td>             <td>                 <input name="softurl1" type="text" id="softurl1" size="35" />               <input name="sel1" type="button" id="sel1" value="选取" onClick="SelectSoft('form1.softurl1')" />               服务器名称:               <input name="servermsg1" type="text" id="servermsg1" value="本地下载" style="width:150px" />             </td>           </tr>         </table>        </td>     </tr>     <?php     if($softconfig['moresitedo'] == 0 && trim($softconfig['sites']) != '')     {     ?>     <tr>       <td height="24" bgcolor="#F9FCEF" class="bline2"><b>&nbsp;预设的镜像服务器:</b></td>     </tr>     <tr class="bline">     <td style="padding-left:10px;">     (服务器地址 + 软件地址 = 软件真实地址 [<a href="soft_config.php" target="_blank"><u>软件频道设置</u></a>])<br />     <?php         $sites = explode("/n", $softconfig['sites']);         $startNum = 2;         foreach($sites as $site)         {             $site = trim($site);             if(empty($site)) continue;             list($siteurl, $sitename) = explode('|', $site);             $siteurl = trim($siteurl);             $sitename = trim($sitename);     ?>     <?php echo $sitename; ?>:     <input type='hidden' name='forconfig<?php echo $startNum; ?>' value='1' />     <input type='text' name='softurlfirst<?php echo $startNum; ?>' style='width:200px' value='<?php echo $siteurl; ?>' /> +     <input type='text' name='softurl<?php echo $startNum; ?>' style='width:120px' value='' />         <input type='text' name='servermsg<?php echo $startNum; ?>' style='width:150px' value='<?php echo $sitename; ?>' />         <input type='checkbox' name='need<?php echo $startNum; ?>' class='np' value='1' checked />启用         <br />         <?php         $startNum++;         }//foreach         echo "<script language='javascript'>startNum = $startNum;</script>/r/n";         ?>       </td>     </tr>     <?php     }//需要预设镜像     ?>     <tr>       <td height="24" bgcolor="#F9FCEF" class="bline2"><b>&nbsp;手动指定地址:</b></td>     </tr>     <tr>       <td height="24"  class="bline" style="padding-left:8px">         <table width="800" border="0" cellspacing="0" cellpadding="0" style="margin-bottom:5px;" class="bline">           <tr>             <td width="90">其它地址:</td>             <td>               <input name="picnum" type="text" id="picnum" size="8" value="5" />               <input name='kkkup' type='button' id='kkkup2' value='增加地址' onClick="MakeUpload();" />               &nbsp;               <input type="button" name="Submit3" id="btsh3" value="隐藏地址" onClick="ShowHideAddr();" />               (最多为30个链接)             </td>           </tr>         </table>         <div id="morelink" style="display:block">                 <div id='uploadfield' style="width:790px"></div>             </div>       </td>     </tr>

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

var startNum = <?php echo $newRowStart?>; 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 += "<div style='line-height:36px'>软件地址"+startNum+":<input type='text' name='softurl"+startNum+"' style='width:280px' value='http://' />  服务器名称:<input type='text' name='servermsg"+startNum+"' style='width:150px' /></div>/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、找到

<tr>       <td colspan="2"><?php       PrintAutoFieldsEdit($cInfos['fieldset'],$addRow,'autofield');       ?></td>     </tr>

在其下边加入以下代码:

<tr>        <td height="24"  class="bline">        <table width="800" border="0" cellpadding="0" cellspacing="0">          <tr>            <td width="90" height="30">&nbsp;需会员权限:</td>            <td width="179" align="center">                <select name="daccess" id="daccess" style="width:90px">                   <?php                 $dsql->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 "     <option value='{$row['rank']}' selected>{$row['membername']}</option>/r/n";                                     else echo "     <option value='{$row['rank']}'>{$row['membername']}</option>/r/n";                 }              ?>                 </select>            </td>            <td width="120" align="center">需消费金币:</td>            <td width="411">              <input name="needmoney" type="text" id="needmoney" value="<?php echo $needmoney; ?>" size="8" />个            </td>          </tr>              <tr>                <td height="26" colspan="4" style="border-top:1px dashed #8EAF61">&nbsp; <span class="STYLE1">(如果设定了下载限制,<a href="soft_config.php" target="_blank"><u>软件频道设置</u></a>中“附件下载方式:”必须选择“链接到跳转页面”) </span></td>            </tr>        </table>        </td>      </tr>      <tr>        <td height="24" colspan="4" bgcolor="#F9FCEF"class="bline2"><strong>&nbsp;软件链接列表:</strong></td>      </tr>      <tr>        <td height="24" colspan="4" class="bline">          <table width="800" border="0" cellspacing="0" cellpadding="0">            <tr>              <td width="72">&nbsp;其它地址:</td>              <td>                  <input name="picnum" type="text" id="picnum" size="8" value="5" />                <input name='kkkup' type='button' id='kkkup2' value='增加数量' onClick="MakeUpload();" />                &nbsp;                <input type="button" name="Submit3" id="btsh3" value="隐藏地址" onClick="ShowHideAddr();" />                (最多为30个链接)               </td>            </tr>          </table>         </td>      </tr>      <tr>        <td height="24" colspan="4" class="bline" style="padding-left:8px">          <?php          echo $nForm;            ?>            <div id='morelink' style='display:block'>              <div id='uploadfield' style='width:800px'></div>            </div>          </td>      </tr>

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,typeid,redirecturl,templet,userip,body,softlinks,needmoney,daccess{$inadd_f}) Values('$arcID','$typeid','$redirecturl','$templet','$useip','$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 = "<input type='checkbox' name='del{$newRowStart}' value='1' />删除";                     else $needmsg = '<input name="sel1" type="button" id="sel1" value="选取" onClick="SelectSoft(/'form1.softurl'.$newRowStart.'/')" />';                     $nForm .= "<div style='line-height:36px'>软件地址{$newRowStart}:<input type='text' name='softurl{$newRowStart}' style='width:280px' value='".trim($ctag->GetInnerText())."' />             服务器名称:<input type='text' name='servermsg{$newRowStart}' value='".$ctag->GetAtt("text")."' style='width:150px' />             <input type='hidden' name='islocal{$newRowStart}' value='{$islocal}' />             $needmsg             </div>/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',body='$body'{$inadd_f},redirecturl='$redirecturl',templet='$templet',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 "<a href=/"/plus/download.php?open=0&aid=".$thisid."&cid=1/" style=/"color:white/" target=/"_blank/">下载地址</a>"; } {/dede:php}

完毕!

以上就是DEDECMS文章模型整合下载功能实例的全部内容,希望对大家的学习和解决疑问有所帮助,也希望大家多多支持武林网。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表