功能:图集图片模型整合下载功能 可判断会员金币数 会员组等权限。

之前网上有人发过一篇关于文章模型整合的教程,小柒改了下,也可以在图集模型使用。

先来看看截图:



前台调用出来是这样的:



注:本教程中的金币和会员组设置只针对下载连接有效。不对文章内容生效,和文章本身的阅读权限和消费金币并不冲突,是分开设置的。文章中所有sql语句中涉及表名的,请把表前缀换成您自己的表前缀。如:dede_addonarticle  dede换成你的表前缀!否则出错!
 
一、首先规划要加入的字段:
下载链接:softlinks
消费金币:needmoney
会员组权限:daccess
 

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

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

下载链接:softlinks

消费金币:needmoney

会员组权限:daccess

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

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


	
  1. ALTER TLE  `js_addonarticle` ADD  `softlinks` TEXT NOT NULL , 
  2. ADD  `needmoney` SMALLINT( 5 ) NOT NULL , 
  3. ADD  `daccess` SMALLINT( 5 ) NOT NULL 

也可以在phpmyadmin中自行添加。

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


	
  1. <field:softlinks  itemname="软件地址" type="softlinks" isnull="true" default="" rename="" /> 
  2. <field:daccess islist="1" itemname="下载级别" type="int" isnull="true" default="0" rename="" function="" notsend="1"/>   
  3. <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>之前加入就行


	
  1. var startNum = 0; 
  2. function MakeUpload() 
  3.     var upfield = document.getElementById("uploadfield"); 
  4.     var endNum =  parseInt(document.form1.picnum.value) + startNum-1; 
  5.     if(endNum > 30) endNum = 30; 
  6.     for(startNum; startNum<=endNum; startNum++){ 
  7.         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"
  8.     } 
  9. function ShowHideAddr() 
  10.     document.getElementById('morelink').style.display = (document.getElementById('morelink').style.display=='block' ? 'none' : 'block'); 
  11.     document.getElementById('morelink').style.height = '100%'
  12.     document.getElementById('btsh3').value = (document.getElementById('morelink').style.display=='block' ? '隐藏地址' : '显示地址'); 

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

2、找到


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

再其后边加入


	
  1. <tr> 
  2.       <td height="24" bgcolor="#F9FCEF"" class="bline2"><strong>&nbsp;下载限制:</strong></td> 
  3.     </tr> 
  4.     <tr> 
  5.       <td height="24"  class="bline"> 
  6.       <table width="800" border="0" cellpadding="0" cellspacing="0"> 
  7.         <tr> 
  8.           <td width="90" height="30">&nbsp;需会员权限:</td> 
  9.           <td width="179" align="left"> 
  10.               <select name="daccess" id="daccess" style="width:90px"> 
  11.                 <?php 
  12.                 $dsql->SetQuery("Select * from `js_arcrank` where rank>=0 "); 
  13.                 $dsql->Execute(); 
  14.                 while($row = $dsql->GetArray()) 
  15.                 { 
  16.                     if($row['rank']==0) $row['membername'] = "不限会员"; 
  17.                                     if($row['rank'] == $softconfig['dfrank']) echo "     <option value='{$row['rank']}' selected>{$row['membername']}</option>\r\n"; 
  18.                                     else echo "     <option value='{$row['rank']}'>{$row['membername']}</option>\r\n"; 
  19.                 } 
  20.              ?> 
  21.                 </select>          </td> 
  22.           <td width="120" align="center">需消费金币:</td> 
  23.           <td width="411"> 
  24.             <input name="needmoney" type="text" id="needmoney" value="<?php echo $softconfig['dfywboy']; ?>" size="8" />个          </td> 
  25.         </tr> 
  26.             <tr> 
  27.               <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> 
  28.           </tr> 
  29.       </table> 
  30.       </td> 
  31.     </tr> 
  32.     <tr> 
  33.       <td height="24" bgcolor="#F9FCEF" class="bline2"><strong>&nbsp;本地软件选择:</strong></td> 
  34.     </tr> 
  35.     <tr> 
  36.       <td height="24"  class="bline"> 
  37.       <table width="800" border="0" cellspacing="0" cellpadding="0"> 
  38.           <tr> 
  39.             <td width="90" height="30">&nbsp;本地地址:</td> 
  40.             <td> 
  41.                 <input name="softurl1" type="text" id="softurl1" size="35" /> 
  42.               <input name="sel1" type="button" id="sel1" value="选取" onClick="SelectSoft('form1.softurl1')" /> 
  43.               服务器名称: 
  44.               <input name="servermsg1" type="text" id="servermsg1" value="本地下载" style="width:150px" /> 
  45.             </td> 
  46.           </tr> 
  47.         </table> 
  48.        </td> 
  49.     </tr> 
  50.     <?php 
  51.     if($softconfig['moresitedo'] == 0 && trim($softconfig['sites']) != '') 
  52.     { 
  53.     ?> 
  54.     <tr> 
  55.       <td height="24" bgcolor="#F9FCEF" class="bline2"><b>&nbsp;预设的镜像服务器:</b></td> 
  56.     </tr> 
  57.     <tr class="bline"> 
  58.     <td style="padding-left:10px;"> 
  59.     (服务器地址 + 软件地址 = 软件真实地址 [<a href="soft_config.php" target="_blank"><u>软件频道设置</u></a>])<br /> 
  60.     <?php 
  61.         $sites = explode("\n", $softconfig['sites']); 
  62.         $startNum = 2
  63.         foreach($sites as $site) 
  64.         { 
  65.             $site = trim($site); 
  66.             if(empty($site)) continue; 
  67.             list($siteurl, $sitename) = explode('|', $site); 
  68.             $siteurl = trim($siteurl); 
  69.             $sitename = trim($sitename); 
  70.     ?> 
  71.     <?php echo $sitename; ?>: 
  72.     <input type='hidden' name='forconfig<?php echo $startNum; ?>' value='1' /> 
  73.     <input type='text' name='softurlfirst<?php echo $startNum; ?>' style='width:200px' value='<?php echo $siteurl; ?>' /> + 
  74.     <input type='text' name='softurl<?php echo $startNum; ?>' style='width:120px' value='' /> 
  75.         <input type='text' name='servermsg<?php echo $startNum; ?>' style='width:150px' value='<?php echo $sitename; ?>' /> 
  76.         <input type='checkbox' name='need<?php echo $startNum; ?>' class='np' value='1' checked />启用 
  77.         <br /> 
  78.         <?php 
  79.         $startNum++; 
  80.         }//foreach 
  81.         echo "<script language='javascript'>startNum = $startNum;</script>\r\n"; 
  82.         ?> 
  83.       </td> 
  84.     </tr> 
  85.     <?php 
  86.     }//需要预设镜像 
  87.     ?> 
  88.     <tr> 
  89.       <td height="24" bgcolor="#F9FCEF" class="bline2"><b>&nbsp;手动指定地址:</b></td> 
  90.     </tr> 
  91.     <tr> 
  92.       <td height="24"  class="bline" style="padding-left:8px"> 
  93.         <table width="800" border="0" cellspacing="0" cellpadding="0" style="margin-bottom:5px;" class="bline"> 
  94.           <tr> 
  95.             <td width="90">其它地址:</td> 
  96.             <td> 
  97.               <input name="picnum" type="text" id="picnum" size="8" value="5" /> 
  98.               <input name='kkkup' type='button' id='kkkup2' value='增加地址' onClick="MakeUpload();" /> 
  99.               &nbsp; 
  100.               <input type="button" name="Submit3" id="btsh3" value="隐藏地址" onClick="ShowHideAddr();" /> 
  101.               (最多为30个链接) 
  102.             </td> 
  103.           </tr> 
  104.         </table> 
  105.         <div id="morelink" style="display:block"> 
  106.                 <div id='uploadfield' style="width:790px"></div> 
  107.             </div> 
  108.       </td> 
  109.     </tr> 

到这里article_add.htm文件就修改完了。

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


	
  1. var startNum = <?php echo $newRowStart?>; 
  2. function MakeUpload() 
  3.     var upfield = document.getElementById('uploadfield'); 
  4.     var endNum =  parseInt(document.form1.picnum.value) + startNum; 
  5.     if(endNum > 30) endNum = 30; 
  6.     for(startNum; startNum < endNum; startNum++) 
  7.     { 
  8.         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"
  9.     } 
  10.  
  11. function ShowHideAddr() 
  12.     document.getElementById('morelink').style.display = (document.getElementById('morelink').style.display=='block' ? 'none' : 'block'); 
  13.     document.getElementById('btsh3').value = (document.getElementById('morelink').style.display=='block' ? '隐藏地址' : '显示地址'); 

4、找到


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

在其下边加入以下代码:


	
  1. <tr>  
  2.       <td height="24"  class="bline">  
  3.       <table width="800" border="0" cellpadding="0" cellspacing="0">  
  4.         <tr>  
  5.           <td width="90" height="30">&nbsp;需会员权限:</td>  
  6.           <td width="179" align="center">  
  7.               <select name="daccess" id="daccess" style="width:90px">  
  8.                  <?php 
  9.                 $dsql->SetQuery("Select * from `js_arcrank` where rank>=0 "); 
  10.                 $dsql->Execute(); 
  11.                 while($row = $dsql->GetArray()) 
  12.                 { 
  13.                     if($row['rank']==0) $row['membername'] = "不限会员"; 
  14.                                     if($row['rank'] == $daccess) echo "     <option value='{$row['rank']}' selected>{$row['membername']}</option>\r\n"; 
  15.                                     else echo "     <option value='{$row['rank']}'>{$row['membername']}</option>\r\n"; 
  16.                 } 
  17.              ?> 
  18.                 </select>  
  19.           </td>  
  20.           <td width="120" align="center">需消费金币:</td>  
  21.           <td width="411">  
  22.             <input name="needmoney" type="text" id="needmoney" value="<?php echo $needmoney; ?>" size="8" />个  
  23.           </td>  
  24.         </tr>  
  25.             <tr>  
  26.               <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>  
  27.           </tr>  
  28.       </table>  
  29.       </td>  
  30.     </tr>  
  31.     <tr>  
  32.       <td height="24" colspan="4" bgcolor="#F9FCEF"class="bline2"><strong>&nbsp;软件链接列表:</strong></td>  
  33.     </tr>  
  34.     <tr>  
  35.       <td height="24" colspan="4" class="bline">  
  36.         <table width="800" border="0" cellspacing="0" cellpadding="0">  
  37.           <tr>  
  38.             <td width="72">&nbsp;其它地址:</td>  
  39.             <td>  
  40.                 <input name="picnum" type="text" id="picnum" size="8" value="5" />  
  41.               <input name='kkkup' type='button' id='kkkup2' value='增加数量' onClick="MakeUpload();" />  
  42.               &nbsp;  
  43.               <input type="button" name="Submit3" id="btsh3" value="隐藏地址" onClick="ShowHideAddr();" />  
  44.               (最多为30个链接)   
  45.             </td>  
  46.           </tr>  
  47.         </table>  
  48.        </td>  
  49.     </tr>  
  50.     <tr>  
  51.       <td height="24" colspan="4" class="bline" style="padding-left:8px">  
  52.         <?php  
  53.         echo $nForm;  
  54.           ?>  
  55.           <div id='morelink' style='display:block'>  
  56.             <div id='uploadfield' style='width:800px'></div>  
  57.           </div>  
  58.         </td>  
  59.     </tr>  

article_edit.html修改完毕,接下来开始修改article_add.php,要认真看哦!

5、打开article_add.php,找到


	
  1. //保存到附加表 
  2.     $cts = $dsql->GetOne("SELECT addtable FROM `js_channeltype` WHERE id='$channelid' "); 

在其上边加入


	
  1. //软件链接列表 
  2.     $urls = ''
  3.  
  4.     //本地链接处理 
  5.     $softurl1 = stripslashes($softurl1); 
  6.     $nsoftsize = ''
  7.     if($softurl1 != ''
  8.     { 
  9.         $urls .= "{dede:link islocal='1' text='{$servermsg1}'} $softurl1 {/dede:link}\r\n"
  10.     } 
  11.  
  12.     //其它链接处理 
  13.     for($i=2; $i<=30; $i++) 
  14.     { 
  15.         if(!(${'softurl'.$i})) 
  16.         { 
  17.             $forconfig = (${'forconfig'.$i}) ? FALSE : TRUE; 
  18.             if($forconfig
  19.             { 
  20.                 if(empty(${'need'.$i})) continue
  21.                 $serverUrl = stripslashes(${'softurlfirst'.$i}); 
  22.                 $serverUrl = preg_replace("#\/$#"""$serverUrl); 
  23.                 $softurl = stripslashes(${'softurl'.$i}); 
  24.                 if( cn_substr($softurl, 1) != '/' ) $softurl = '/'.$softurl
  25.                 $softurl = $serverUrl.$softurl
  26.             } 
  27.             else 
  28.             { 
  29.                 $softurl = stripslashes(${'softurl'.$i}); 
  30.             } 
  31.             $servermsg = str_replace("'"""stripslashes(${'servermsg'.$i})); 
  32.             if($servermsg==''$servermsg = '下载地址'.$i
  33.             if($softurl != 'http://'
  34.             { 
  35.                 $urls .= "{dede:link text='$servermsg'} $softurl {/dede:link}\r\n"
  36.             } 
  37.         } 
  38.     } 
  39.     $urls = addslashes($urls); 

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


	
  1. $query = "INSERT INTO `{$addtable}`(aid,typeid,redirecturl,templet,userip,body{$inadd_f}) Values('$arcID','$typeid','$redirecturl','$templet','$useip','$body'{$inadd_v})"

替换为


	
  1. $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,找到


	
  1. $channelid = $arcRow['channel']; 

在其上边加入


	
  1. $newRowStart = 1; 
  2.     $nForm = ''
  3.     $daccess = $addRow['daccess']; 
  4.     $needmoney = $addRow['needmoney']; 
  5.     if($addRow['softlinks'] != ''
  6.     { 
  7.         $dtp = new DedeTagParse(); 
  8.         $dtp->LoadSource($addRow['softlinks']); 
  9.         if(is_array($dtp->CTags)) 
  10.         { 
  11.             foreach($dtp->CTags as $ctag
  12.             { 
  13.                 if($ctag->GetName()=='link'
  14.                 { 
  15.                     $islocal = $ctag->GetAtt('islocal'); 
  16.                     if($islocal != 1) $needmsg = "<input type='checkbox' name='del{$newRowStart}' value='1' />删除"
  17.                     else $needmsg = '<input name="sel1" type="button" id="sel1" value="选取" onClick="SelectSoft(\'form1.softurl'.$newRowStart.'\')" />'
  18.                     $nForm .= "<div style='line-height:36px'>软件地址{$newRowStart}:<input type='text' name='softurl{$newRowStart}' style='width:280px' value='".trim($ctag->GetInnerText())."' /> 
  19.             服务器名称:<input type='text' name='servermsg{$newRowStart}' value='".$ctag->GetAtt("text")."' style='width:150px' /> 
  20.             <input type='hidden' name='islocal{$newRowStart}' value='{$islocal}' /> 
  21.             $needmsg 
  22.             </div>\r\n"; 
  23.                     $newRowStart++; 
  24.                 } 
  25.             } 
  26.         } 
  27.         $dtp->Clear(); 
  28.     } 

找到


	
  1. $cts = $dsql->GetOne("SELECT addtable FROM `js_channeltype` WHERE id='$channelid' "); 

在其上边加入以下代码:


	
  1. //软件链接列表 
  2.     $urls = ''
  3.      
  4.     for($i=1; $i<=30; $i++) 
  5.     { 
  6.         if(!empty(${'softurl'.$i})) 
  7.         { 
  8.             $islocal = empty(${'islocal'.$i}) ? '' : 1; 
  9.             $isneed = empty(${'del'.$i}) ? true : false; 
  10.             $servermsg = str_replace("'",'',stripslashes(${'servermsg'.$i})); 
  11.             $softurl = stripslashes(${'softurl'.$i}); 
  12.              
  13.             if($servermsg==''
  14.             { 
  15.                 $servermsg = '下载地址'.$i
  16.             } 
  17.             if($softurl != 'http://'
  18.             { 
  19.                 if($islocal==1) $urls .= "{dede:link islocal='$islocal' text='{$servermsg}'} $softurl {/dede:link}\r\n" ; 
  20.                 else if($isneed$urls .= "{dede:link text='$servermsg'} $softurl {/dede:link}\r\n"
  21.                 else continue
  22.             } 
  23.         } 
  24.     } 
  25.     $urls = addslashes($urls); 

找到


	
  1. $iquery = "UPDATE `$addtable` SET typeid='$typeid',body='$body'{$inadd_f},redirecturl='$redirecturl',templet='$templet',userip='$useip' WHERE aid='$id'"

替换为:


	
  1. $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'"

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

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


	
  1. {dede:field name='softlinks'/} 

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

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


	
  1. {dede:php} 
  2.         $thisid = $refObj->Fields['aid'];  
  3.         $totrow=$dsql->GetOne('select * from js_addonarticle where aid='.$thisid); 
  4.         if($totrow['softlinks']!=''
  5.         { 
  6.         echo "<a href=\"/plus/download.php?open=0&aid=".$thisid."&cid=1\" style=\"color:white\" target=\"_blank\">下载地址</a>"
  7.         } 
  8. {/dede:php} 



以上教程只针对文章模型,如需要图集模型也实现该功能,请先到数据库中表中删除softlinks(不然会出错)

然后把dede_addonarticle  修改为:js_addonimages  如

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


  1. ALTER TLE  `dede_addonimages` ADD  `softlinks` TEXT NOT NULL , 
  2. ADD  `needmoney` SMALLINT( 5 ) NOT NULL , 
  3. ADD  `daccess` SMALLINT( 5 ) NOT NULL 


图集增加下载功能的插件:下载地址:http://pan.baidu.com/s/1dDkzSzf