2018全新源码上线了----全部免费源码上源码上线了     

您现在的位置: 主页 > 织梦问学 > 织梦会员开发 >

织梦设置下载链接需要权限的方法

来源:未知 发布时间:2018-02-15热度: ℃
本教程实现 DEDEC MS 功能:文章模型整合下载功能,可判断点数,会员组等下载权限,前台可判断是否有附件下载,有则显示,没有则不显示。适用类型:有些文章有下载地址,有些文章...

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

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

后台效果图

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

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

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

下载链接:softlinks

消费金币:needmoney

会员组权限:daccess

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

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

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

也可以在phpmyadmin中自行添加。

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

  1.  
  2.    
  3.  

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

二、数据库字段添加完毕就要修改文章模型的4个文件了。分别是dede管理目录下的article_add.php,article_edit.php和管理yabo88下载亚博体育「信誉网站」article_add.htm,article_edit.htm,打开这4个文件依次修改。

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

  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 += "软件地址"+startNum+":  服务器名称:
"; 
  •     } 
  • 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、找到

    1.  
    2.       
    3.     

    再其后边加入

    1.  
    2.        下载限制: 
    3.      
    4.      
    5.        
    6.        
    7.          
    8.            需会员权限: 
    9.            
    10.                
    11.                 
    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 "     {$row['membername']} "; 
    18.                                     else echo "     {$row['membername']} "; 
    19.                 } 
    20.              ?> 
    21.                            
    22.           需消费金币: 
    23.            
    24.             " size="8" />个           
    25.          
    26.              
    27.                 (如果设定了下载限制,[软件频道设置]中“附件下载方式:”必须选择“链接到跳转页面”)  
    28.            
    29.        
    30.        
    31.      
    32.      
    33.        本地软件选择: 
    34.      
    35.      
    36.        
    37.        
    38.            
    39.              本地地址: 
    40.              
    41.                  
    42.                
    43.               服务器名称: 
    44.                
    45.              
    46.            
    47.          
    48.         
    49.      
    50.     
    51.     if($softconfig['moresitedo'] == 0 && trim($softconfig['sites']) != '') 
    52.     { 
    53.     ?> 
    54.      
    55.        预设的镜像服务器: 
    56.      
    57.      
    58.      
    59.     (服务器地址 + 软件地址 = 软件真实地址 [软件频道设置]) 
    60.     
    61.         $sites = explode(" ", $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.     : 
    72.     ' value='1' /> 
    73.     ' style='width:200px' value='' /> + 
    74.     ' style='width:120px' value='' /> 
    75.         ' style='width:150px' value='' /> 
    76.         ' class='np' value='1' checked />启用 
    77.          
    78.         
    79.         $startNum++; 
    80.         }//foreach 
    81.         echo "startNum = $startNum; "; 
    82.         ?> 
    83.        
    84.      
    85.     
    86.     }//需要预设镜像 
    87.     ?> 
    88.      
    89.        手动指定地址: 
    90.      
    91.      
    92.        
    93.          
    94.            
    95.             其它地址: 
    96.              
    97.                
    98.                
    99.                 
    100.                
    101.               (最多为30个链接) 
    102.              
    103.            
    104.          
    105.          
    106.                 
     
  •             
  •  
  •        
  •      
  • 到这里article_add.htm文件就修改完了。

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

    1. var startNum = 
    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 += "软件地址"+startNum+":  服务器名称:
    "; 
  •     } 
  •  
  • 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、找到

    1.  
    2.       
    3.       PrintAutoFieldsEdit($cInfos['fieldset'],$addRow,'autofield'); 
    4.       ?> 
    5.      

    在其下边加入以下代码:

    1.   
    2.         
    3.         
    4.           
    5.            需会员权限:  
    6.             
    7.                 
    8.                  
    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 "     {$row['membername']} "; 
    15.                                     else echo "     {$row['membername']} "; 
    16.                 } 
    17.              ?> 
    18.                   
    19.             
    20.           需消费金币:  
    21.             
    22.             " size="8" />个  
    23.             
    24.           
    25.               
    26.                 (如果设定了下载限制,软件频道设置中“附件下载方式:”必须选择“链接到跳转页面”)   
    27.             
    28.         
    29.         
    30.       
    31.       
    32.        软件链接列表:  
    33.       
    34.       
    35.         
    36.           
    37.             
    38.              其它地址:  
    39.               
    40.                   
    41.                 
    42.                  
    43.                 
    44.               (最多为30个链接)   
    45.               
    46.             
    47.           
    48.          
    49.       
    50.       
    51.         
    52.         
    53.         echo $nForm;  
    54.           ?>  
    55.             
    56.             
      
  •             
  •           
  •       
  • 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} "; 
    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} "; 
    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 = "删除"; 
    17.                     else $needmsg = ''; 
    18.                     $nForm .= "软件地址{$newRowStart}:GetInnerText())."' /> 
    19.             服务器名称:GetAtt("text")."' style='width:150px' /> 
    20.              
    21.             $needmsg 
    22.              "; 
    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} " ; 
    20.                 else if($isneed) $urls .= "{dede:link text='$servermsg'} $softurl {/dede:link} "; 
    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'/} 

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

    有一种情况,就是有些网友希望没有下载地址的话就不显示,这里可以提供一种方法。把如下代码复制到文章yabo88下载亚博体育「信誉网站」里即可。

    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 "下载地址"; 
    7.         } 
    8. {/dede:php} 

    前台效果图

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

    本文地址:http://www.squanzi.com/a/zhimenghuiyuankaifa/20180215/1.html

    责任编辑:admin

    上一篇:没有了

    下一篇:织梦内页下载链接需要扣除金币设置方法

    相关阅读