<optgroup id="sosok"><acronym id="sosok"></acronym></optgroup><table id="sosok"></table>
  • <li id="sosok"></li>
    <kbd id="sosok"></kbd>
  • <optgroup id="sosok"><acronym id="sosok"></acronym></optgroup>
    <option id="sosok"></option>
  • AB模板網:專注于dede模板,織夢源碼,織夢模板,網站模板下載,dedecms模板,網站源碼,dedecms教程以及各類手機網站模板和企業網站模板分享.

    織夢模板

    網站模板搜索
    營銷型模板 政府網站模板 自適應模板 雙語模板 標簽大全

    注冊

    dedecms 刪除文章同時刪除圖片的方法

    AB模板網 / 2021-07-01
    有時候我們刪除文章的時候,文章的圖片還是會留存在你的圖片文件夾上面,這樣很占服務器的內存,程序也會變得很大,所以我們需要刪除文章的同時把文章里的圖片也對應的刪掉,
    但織夢本身是不支持的,需要經過小的二次開發才可以,下面織夢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);//去掉網址部分
    
    $path .=$picpath;
    
    $delfiles[] = $path;//保存處理后的數據
    
    }
    
    return $delfiles;
    
    }
    
    function WriteToDelFiles($msg)//刪除文章的時候會通過此函數記錄日志
    
    {
    
    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_catalogs, $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_catalogs) && (count($admin_catalogs) != 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.813358.com/dedecmsjc/8812.html

    有問題可以加入織夢技術QQ群一起交流學習

    ☉首先聲明,只要是我們的vip會員全站所有資源均可以免費下載,不做任何限制(了解更多)

    ☉本站的源碼不會像其它下載站一樣植入大量的廣告。

    ☉本站提供的織夢源碼,都是做好測試好發布的,均可放心使用。

    ☉本站提供的織夢源碼,均帶數據及演示地址。可以在任一源碼詳情頁查看演示地址。

    ☉為了vip利益的最大化,我們還提供了vip贈品(了解更多

    ☉如有其他問題,請加網站客服QQ(9490489)進行交流。

    相關教程

    織夢模板_隨機Tags

    衣柜掛件網站模板 windows系統網站模板 鐘表網站模板 黃金網站模板 建筑建材網站模板 獸藥網站模板 展柜展覽網站模板 育兒經驗網站模板 工業廢水網站模板 環保燈網站模板 餐飲裝修網站模板 地質勘測網站模板

    推薦教程

    首頁 VIP專區 html模板 會員中心
    第一福利视频网站在线,久草在线新视免费首页,久草草在线视视频免费为大家提供最新最全的免费电影,电视剧,综艺,动漫无广告在线云点播,全网更新最快。希望大家喜欢!