GVKun编程网logo

DEDECMS调用新闻下所有图片集中在一起的办法

6

本文将分享DEDECMS调用新闻下所有图片集中在一起的办法的详细内容,此外,我们还将为大家带来关于arclist标签调用副栏目新闻的办法fordedecms、dede内容页调用图片集下所有图片方法!、

本文将分享DEDECMS调用新闻下所有图片集中在一起的办法的详细内容,此外,我们还将为大家带来关于arclist标签调用副栏目新闻的办法 for dedecms、dede 内容页调用图片集下所有图片方法!、dedecms v5.7 图片集 “图集内容” 无法调用的解决办法、dedecms 删除新闻同时删除图片的办法的相关知识,希望对你有所帮助。

本文目录一览:

DEDECMS调用新闻下所有图片集中在一起的办法

DEDECMS调用新闻下所有图片集中在一起的办法

 

在做download站或者源码展示网站及其他需要把图片集中在一起展示,又不想使用图集模块功能的,就可以使用这个办法,可以在新闻页,把该新闻下发布的所有图片集中调用到一起展示

类似:

DEDECMS调用文章下所有图片集中在一起的方案

其实要实现很简单,利用到DEDE的SQL函数

{dede:sql sql='Select u.title,u.url from dede_archives as a left join dede_uploads as u on a.id=u.arcid where  a.litpic <> u.url and a.id=~id~'}

<li><a href="javascript:void(0);" ><img src=http://www.dede58.com/a/dedejq/"[field:url/]" alt="[field:title function='html2text(@me)'/]" width="110" height="76"/></a></li>

{/dede:sql}


联合查询dede_archives和dede_uploads两个表,读取该新闻id下的所有图片文件

其中a.litpic <> u.url这个语句是用于去除缩略图

而且这个语句可以在首页、列表、频道首页调用某篇新闻的所有图片,做相册特效、幻灯特效都很简单。不过在首页、栏目页调用所有图片,需要在common.func.php中写一个函数,根据新闻id查询这两个表,返回一长串的<li><a href="javascript:void(0);" ><img src=http://www.dede58.com/a/dedejq/"[field:url/]" alt="[field:title function='html2text(@me)'/]" width="110" height="76"/></a></li>,语句和这个差不多

本文章网址:http://www.ppssdd.com/code/10281.html。转载请保留出处,谢谢合作!

arclist标签调用副栏目新闻的办法 for dedecms

arclist标签调用副栏目新闻的办法 for dedecms

 

*近一段时间以来,有不少时间都在折腾DEDECMS,对其进行了不少的优化工作,以便其适应我的应用要求。在这其中,也遇到了不少的问题。譬如:DEDECMS根据副栏目进行新闻调用的问题。
DEDECMS中一个新闻可以同时属于两个栏目,即一个主栏目一个副栏目,{dede:arclist} 属性中可以通过typeid进行主栏目有效性筛选,但是有时我们却想根据副栏目进行筛选,查了dedecms的在线用户手册发现没有此功能,*后搜索到一个有效地解决方案。只需修改标签对应的源文件。

查找 dedecmsROOT/include/taglib/arclist.lib.php 文件,大概在第212行代码处。
if($CrossID=='') $orwheres[] = ' arc.typeid in ('.GetSonIds($typeid).')';
else $orwheres[] = ' arc.typeid in ('.GetSonIds($typeid).','.$CrossID.')';

替换为:
if($CrossID=='')
$orwheres[] = ' typeid in ('.GetSonIds($typeid).') or typeid2 in ('.GetSonIds($typeid).')';
else
$orwheres[] = ' typeid in ('.GetSonIds($typeid).','.$CrossID.') or typeid2 in ('.GetSonIds($typeid).','.$CrossID.')';
示例:{dede:arclist typeid=’2,3,4′}….{/dede:arclist}

通过以上方案,有效地解决了DEDECMS*新版本V5.6正式版(2010-08-18)(包括在此前的版本),不支持通过arclist标签调用副栏目新闻的问题。

本文章网址:http://www.ppssdd.com/code/14678.html。转载请保留出处,谢谢合作!

dede 内容页调用图片集下所有图片方法!

dede 内容页调用图片集下所有图片方法!

http://blog.csdn.net/forest_fire/article/details/50943765

dede内容页调用图片集下所有图片方法!

版权声明:本文为博主原创文章,未经博主允许不得转载。

{dede:productimagelist} 

  • JavaScript:ChangePic(''[field:imgsrc/]'', ''#bigpicimg'');" title="[field:text/]" rel="facebox">
  •  
    {/dede:productimagelist}

本文同步分享在 博客 “lxw1844912514”(CSDN)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与 “OSC 源创计划”,欢迎正在阅读的你也加入,一起分享。

dedecms v5.7 图片集 “图集内容” 无法调用的解决办法

dedecms v5.7 图片集 “图集内容” 无法调用的解决办法

在 dedecms 的图片集模型或者基于图片集模型修改的自定义模型中

内容页模板使用 {dede:field.body/} 方式来调用 body 字段是没有输出的(原因不明,未继续深入)

但有些时候当需要在内容页调用这个 “图集内容” 时,

 

可以这样:

修改 include/extend.func.PHP知识库" target="_blank">PHP, 添加如下函数:
 

function getimgsetbody($id)  
{  
        global $dsql;  
        $row = $dsql->GetOne ("SELECT body FROM`dede_addonxxx`WHERE aid= ''$id''");//addonxxx 是模型附加表  
        $res = $row[''body''];  
        return $res;  
}  


内容页模板调用处可以这么调用:
{dede:field.body/}  //lxw 实际用时需要加
{dede:field name=''id'' function=getimgsetbody(''@me'')/}

跟版网 - 专业织梦模板下载平台,转载请注明出处:http://www.genban.org/news/dedecms-17169.html

本文同步分享在 博客 “lxw1844912514”(CSDN)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与 “OSC 源创计划”,欢迎正在阅读的你也加入,一起分享。

dedecms 删除新闻同时删除图片的办法

dedecms 删除新闻同时删除图片的办法

 

有时候我们删除新闻的时候,新闻的图片还是会留存在你的图片文件夹上面,这样很占服务器的内存,程序也会变得很大,所以我们需要删除新闻的同时把新闻里的图片也对应的删掉,
但织梦本身是不支持的,需要经过小的二开才可以,下面织梦58符老师教你们如何做,经过测试可以用的,

首先需要修改的php文件修改前备份好!

*步找到 

/include/extend.func.php

复制以下的全部代码直接覆盖 到 extend.func.php 文件

<?php function GetPicsTruePath($body,$litpic) //解析body数据,获得所有图片的**地址 { $delfiles = array();//存储图片地址数据 if(!empty($litpic)) { $litpicpath = GetTruePath(); $litpicpath .= $litpic; $delfiles[] = $litpicpath;//缩略图地址 } preg_match_all("/src=[\"|'|\S|\s]([^ |\/|>]*){0,}(([^>]*)\.(gif|jpg|png))/isU",$body,$tmpdata); $picspath = array_unique($tmpdata[2]);//body中所有图片的地址 foreach($picspath as $tmppath) { $path = GetTruePath();//获得**路径 $picpath = preg_replace("/[a-zA-z]+:\/\/[^ |\/|\s]*/",'',$tmppath);//去掉URL部分 $path .=$picpath; $delfiles[] = $path;//保存处理后的数据 } return $delfiles; } function WriteToDelFiles($msg)//删除新闻的时候会通过此函数记录log { if(empty($msg)) $savemsg="未获得消息"; else $savemsg = $msg; $errorFile = dirname(__FILE__).'/../data/del_body_file.txt';//删除记录文件 $fp = @fopen($errorFile, 'a'); @fwrite($fp,"\r\n{$savemsg}"); @fclose($fp); } //获得新闻Body数据 function GetArcBody($aid) { global $dsql; $query = "SELECT dede_addonarticle.body FROM dede_addonarticle WHERE dede_addonarticle.aid = '$aid'"; $row = $dsql->GetOne($query); if(is_array($row)) return $row; else return false; } function litimgurls($imgid=0){ global $lit_imglist; $dsql = new DedeSql(false); //获取附加表 $row = $dsql->GetOne("SELECT c.addtable FROM dede_archives AS a LEFT JOIN dede_channeltype AS c ON a.channel=c.id where a.id='$imgid'"); $addtable = trim($row['addtable']); //获取图片附加表imgurls字段内容进行处理 $row = $dsql->GetOne("Select imgurls From `$addtable` where aid='$imgid'"); //调用inc_channel_unit.php中ChannelUnit类 $ChannelUnit = new ChannelUnit(2,$imgid); //调用ChannelUnit类中GetlitImgLinks办法处理缩略图 $lit_imglist = $ChannelUnit->GetlitImgLinks($row['imgurls']); //返回结果 return $lit_imglist; } ?>  


第二步 找到

\dede\inc\inc_batchup.php

复制以下的全部代码直接覆盖 到 inc_batchup.php 文件

<?php function DelArc($aid,$type='ON',$onlyfile=false) { global $dsql,$cfg_cookie_encode,$cfg_multi_site,$cfg_medias_dir; global $cuserLogin,$cfg_upload_switch,$cfg_delete,$cfg_basedir; global $admin_cata日志s, $cfg_admin_channel; if($cfg_delete == 'N') $type = 'OK'; if(empty($aid)) return ; $aid = ereg_replace("[^0-9]", '', $aid); $arctitle = $arcurl = ''; //查询表信息 $query = "Select ch.maintable,ch.addtable,ch.nid,ch.issystem From `dede_arctiny` arc left join `dede_arctype` tp on tp.id=arc.typeid left join `dede_channeltype` ch on ch.id=arc.channel where arc.id='$aid' "; $row = $dsql->GetOne($query); $nid = $row['nid']; $maintable = (trim($row['maintable'])=='' ? 'dede_archives' : trim($row['maintable'])); $addtable = trim($row['addtable']); $issystem = $row['issystem']; //查询档案信息 if($issystem==-1) { $arcQuery = "Select arc.*,tp.* from `$addtable` arc left join `dede_arctype` tp on arc.typeid=tp.id where arc.aid='$aid' "; } else { $arcQuery = "Select arc.*,tp.*,arc.id as aid from `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id where arc.id='$aid' "; } $arcRow = $dsql->GetOne($arcQuery); $arcBodyRow = GetArcBody($aid); //检测权限 if(!TestPurview('a_Del,sys_ArcBatch')) { if(TestPurview('a_AccDel')) { if( !in_array($arcRow['typeid'], $admin_cata日志s) && (count($admin_cata日志s) != 0 || $cfg_admin_channel != 'all') ) { return false; } } else if(TestPurview('a_MyDel')) { if($arcRow['mid'] != $cuserLogin->getUserID()) { return false; } } else { return false; } } //$issystem==-1 是单表模型,不使用回收站 if($issystem == -1) $type = 'OK'; if(!is_array($arcRow)) return false; /** 删除到回收站 **/ if($cfg_delete == 'Y' && $type == 'ON') { $dsql->ExecuteNoneQuery("Update `$maintable` set arcrank='-2' where id='$aid' "); $dsql->ExecuteNoneQuery("Update `dede_arctiny` set `arcrank` = '-2' where id = '$aid'; "); } else { //删除数据库记录 if(!$onlyfile) { //删除相关附件 if($cfg_upload_switch == 'Y') { $dsql->Execute("me", "SELECT * FROM `dede_uploads` WHERE arcid = '$aid'"); while($row = $dsql->GetArray('me')) { $addfile = $row['url']; $aid = $row['aid']; $dsql->ExecuteNoneQuery("Delete From `dede_uploads` where aid = '$aid' "); $upfile = $cfg_basedir.$addfile; if(@file_exists($upfile)) @unlink($upfile); } } $dsql->ExecuteNoneQuery("Delete From `dede_arctiny` where id='$aid'"); if($addtable != '') { $dsql->ExecuteNoneQuery("Delete From `$addtable` where aid='$aid' "); } if($issystem != -1) { $dsql->ExecuteNoneQuery("Delete From `dede_archives` where id='$aid' "); } $dsql->ExecuteNoneQuery("Delete From `dede_feedback` where aid='$aid' "); $dsql->ExecuteNoneQuery("Delete From `dede_member_stow` where aid='$aid' "); $dsql->ExecuteNoneQuery("Delete From `dede_taglist` where aid='$aid' "); $dsql->ExecuteNoneQuery("Delete From `dede_erradd` where aid='$aid' "); } //删除文本数据 $filenameh = DEDEDATA."/textdata/".(ceil($aid/5000))."/{$aid}-".substr(md5($cfg_cookie_encode),0,16).".txt"; if(@is_file($filenameh)) @unlink($filenameh); } if(empty($arcRow['money'])) $arcRow['money'] = 0; if(empty($arcRow['ismake'])) $arcRow['ismake'] = 1; if(empty($arcRow['arcrank'])) $arcRow['arcrank'] = 0; if(empty($arcRow['filename'])) $arcRow['filename'] = ''; //删除HTML if($arcRow['ismake']==-1 || $arcRow['arcrank']!=0 || $arcRow['typeid']==0 || $arcRow['money']>0) { return true; } //强制转换非多站点模式,以便统一方式获得实际HTML文件 $GLOBALS['cfg_multi_site'] = 'N'; $arcurl = GetFileUrl($arcRow['aid'],$arcRow['typeid'],$arcRow['senddate'],$arcRow['title'],$arcRow['ismake'], $arcRow['arcrank'],$arcRow['namerule'],$arcRow['typedir'],$arcRow['money'],$arcRow['filename']); if(!ereg("\?", $arcurl)) { $htmlfile = GetTruePath().str_replace($GLOBALS['cfg_basehost'],'',$arcurl); if(file_exists($htmlfile) && !is_dir($htmlfile)) { @unlink($htmlfile); $arcurls = explode(".", $htmlfile); $sname = $arcurls[count($arcurls)-1]; $fname = ereg_replace("(\.$sname)$", "", $htmlfile); for($i=2; $i<=100; $i++) { $htmlfile = $fname."_{$i}.".$sname; if( @file_exists($htmlfile) ) @unlink($htmlfile); else break; } } } //解析Body中的资源,并删除 $willDelFiles = GetPicsTruePath($arcBodyRow['body'],$arcRow['litpic']); $nowtime = time(); $executetime = MyDate('Y-m-d H:i:s',$nowtime);//获得执行时间 $msg = "\r\n新闻标题:$arcRow[title]"; WriteToDelFiles($msg); if(!empty($willDelFiles)) { foreach($willDelFiles as $file) { if(file_exists($file) && !is_dir($file)) { if(unlink($file)) $msg = "\r\n位置:$file\r\n结果:删除成功!\r\n时间:$executetime"; else $msg = "\r\n位置:$file\r\n结果:删除失败!\r\n时间:$executetime"; } else $msg = "\r\n位置:$file\r\n结果:文件不存!\r\n时间:$executetime"; WriteToDelFiles($msg); }//END foreach } else { $msg = "\r\n未在Body中解析到数据\r\nBody原始数据:$arcBodyRow[body]\r\n时间:$executetime"; WriteToDelFiles($msg); } return true; } //获取真实路径 function GetTruePath($siterefer='', $sitepath='') { $truepath = $GLOBALS['cfg_basedir']; return $truepath; } ?>  


到这里就结束了 ,很简单吧, 我们再去试着删除一篇新闻 ,你会发现你删除这篇新闻以后,这篇新闻的缩列图和内容上的图片都同时删除了!


本文章网址:http://www.ppssdd.com/code/8133.html。转载请保留出处,谢谢合作!

今天关于DEDECMS调用新闻下所有图片集中在一起的办法的讲解已经结束,谢谢您的阅读,如果想了解更多关于arclist标签调用副栏目新闻的办法 for dedecms、dede 内容页调用图片集下所有图片方法!、dedecms v5.7 图片集 “图集内容” 无法调用的解决办法、dedecms 删除新闻同时删除图片的办法的相关知识,请在本站搜索。

本文标签: