校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 網(wǎng)站建設(shè) > 建站知識 > dede織夢刪除文章同時刪除關(guān)聯(lián)圖片的方法

dede織夢刪除文章同時刪除關(guān)聯(lián)圖片的方法

POST TIME:2020-03-30 20:07

有時候我們刪除文章的時候,文章的圖片還是會留存在你的圖片文件夾上面,這樣很占服務(wù)器的內(nèi)存,程序也會變得很大,所以我們需要刪除文章的同時把文章里的圖片也對應(yīng)的刪掉,
但織夢本身是不支持的,需要經(jīng)過小的二次開發(fā)才可以,下面織夢58符老師教你們怎么做,經(jīng)過測試可以用的,

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

第一步找到 

/include/extend.func.php

復(fù)制以下的全部代碼直接覆蓋 到 extend.func.php 文件

001 <?php
002  
003 function GetPicsTruePath($body,$litpic) //解析body數(shù)據(jù),獲得所有圖片的絕對地址
004  
005 {
006  
007 $delfiles = array();//存儲圖片地址數(shù)據(jù)
008  
009 if(!empty($litpic))
010  
011 {
012  
013 $litpicpath = GetTruePath();
014  
015 $litpicpath .= $litpic;
016  
017 $delfiles[] = $litpicpath;//縮略圖地址
018  
019 }
020  
021 preg_match_all("/src=[\"|'|\S|\s]([^ |\/|>]*){0,}(([^>]*)\.(gif|jpg|png))/isU",$body,$tmpdata);
022  
023 $picspath = array_unique($tmpdata[2]);//body中所有圖片的地址
024  
025 foreach($picspath as $tmppath)
026  
027 {
028  
029 $path = GetTruePath();//獲得絕對路徑
030  
031 $picpath = preg_replace("/[a-zA-z]+:\/\/[^ |\/|\s]*/",'',$tmppath);//去掉網(wǎng)址部分
032  
033 $path .=$picpath;
034  
035 $delfiles[] = $path;//保存處理后的數(shù)據(jù)
036  
037 }
038  
039 return $delfiles;
040  
041 }
042  
043 function WriteToDelFiles($msg)//刪除文章的時候會通過此函數(shù)記錄日志
044  
045 {
046  
047 if(empty($msg)) $savemsg="未獲得消息";
048  
049 else $savemsg = $msg;
050  
051 $errorFile = dirname(__FILE__).'/../data/del_body_file.txt';//刪除記錄文件
052  
053 $fp = @fopen($errorFile, 'a');
054  
055 @fwrite($fp,"\r\n{$savemsg}");
056  
057 @fclose($fp);
058  
059 }
060  
061 //獲得文章Body數(shù)據(jù)
062  
063 function GetArcBody($aid)
064  
065 {
066  
067 global $dsql;
068  
069 $query = "SELECT dede_addonarticle.body FROM dede_addonarticle WHERE dede_addonarticle.aid = '$aid'";
070  
071 $row = $dsql->GetOne($query);
072  
073 if(is_array($row)) return $row;
074  
075 else return false;
076  
077 }
078  
079 function litimgurls($imgid=0){
080  
081 global $lit_imglist;
082  
083 $dsql = new DedeSql(false);
084  
085 //獲取附加表
086  
087 $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'");
088  
089 $addtable = trim($row['addtable']);
090  
091 //獲取圖片附加表imgurls字段內(nèi)容進(jìn)行處理
092  
093 $row = $dsql->GetOne("Select imgurls From `$addtable` where aid='$imgid'");
094  
095 //調(diào)用inc_channel_unit.php中ChannelUnit類
096  
097 $ChannelUnit = new ChannelUnit(2,$imgid);
098  
099 //調(diào)用ChannelUnit類中GetlitImgLinks方法處理縮略圖
100  
101 $lit_imglist = $ChannelUnit->GetlitImgLinks($row['imgurls']);
102  
103 //返回結(jié)果
104  
105 return $lit_imglist;
106  
107 }
108  
109 ?>



第二步 找到

\dede\inc\inc_batchup.php

復(fù)制以下的全部代碼直接覆蓋 到 inc_batchup.php 文件
 

001 <?php
002  
003 function DelArc($aid,$type='ON',$onlyfile=false)
004  
005 {
006  
007 global $dsql,$cfg_cookie_encode,$cfg_multi_site,$cfg_medias_dir;
008  
009 global $cuserLogin,$cfg_upload_switch,$cfg_delete,$cfg_basedir;
010  
011 global $admin_catalogs, $cfg_admin_channel;
012  
013 if($cfg_delete == 'N') $type = 'OK';
014  
015 if(empty($aid)) return ;
016  
017 $aid = ereg_replace("[^0-9]", '', $aid);
018  
019 $arctitle = $arcurl = '';
020  
021 //查詢表信息
022  
023 $query = "Select ch.maintable,ch.addtable,ch.nid,ch.issystem From `dede_arctiny` arc
024  
025 left join `dede_arctype` tp on tp.id=arc.typeid
026  
027 left join `dede_channeltype` ch on ch.id=arc.channel where arc.id='$aid' ";
028  
029 $row = $dsql->GetOne($query);
030  
031 $nid = $row['nid'];
032  
033 $maintable = (trim($row['maintable'])=='' ? 'dede_archives' : trim($row['maintable']));
034  
035 $addtable = trim($row['addtable']);
036  
037 $issystem = $row['issystem'];
038  
039 //查詢檔案信息
040  
041 if($issystem==-1)
042  
043 {
044  
045 $arcQuery = "Select arc.*,tp.* from `$addtable` arc left join `dede_arctype` tp on arc.typeid=tp.id where arc.aid='$aid' ";
046  
047 }
048  
049 else
050  
051 {
052  
053 $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' ";
054  
055 }
056  
057 $arcRow = $dsql->GetOne($arcQuery);
058  
059 $arcBodyRow = GetArcBody($aid);
060  
061 //檢測權(quán)限
062  
063 if(!TestPurview('a_Del,sys_ArcBatch'))
064  
065 {
066  
067 if(TestPurview('a_AccDel'))
068  
069 {
070  
071 if( !in_array($arcRow['typeid'], $admin_catalogs) && (count($admin_catalogs) != 0 || $cfg_admin_channel != 'all') )
072  
073 {
074  
075 return false;
076  
077 }
078  
079 }
080  
081 else if(TestPurview('a_MyDel'))
082  
083 {
084  
085 if($arcRow['mid'] != $cuserLogin->getUserID())
086  
087 {
088  
089 return false;
090  
091 }
092  
093 }
094  
095 else
096  
097 {
098  
099 return false;
100  
101 }
102  
103 }
104  
105 //$issystem==-1 是單表模型,不使用回收站
106  
107 if($issystem == -1) $type = 'OK';
108  
109 if(!is_array($arcRow)) return false;
110  
111 /** 刪除到回收站 **/
112  
113 if($cfg_delete == 'Y' && $type == 'ON')
114  
115 {
116  
117 $dsql->ExecuteNoneQuery("Update `$maintable` set arcrank='-2' where id='$aid' ");
118  
119 $dsql->ExecuteNoneQuery("Update `dede_arctiny` set `arcrank` = '-2' where id = '$aid'; ");
120  
121 }
122  
123 else
124  
125 {
126  
127 //刪除數(shù)據(jù)庫記錄
128  
129 if(!$onlyfile)
130  
131 {
132  
133 //刪除相關(guān)附件
134  
135 if($cfg_upload_switch == 'Y')
136  
137 {
138  
139 $dsql->Execute("me", "SELECT * FROM `dede_uploads` WHERE arcid = '$aid'");
140  
141 while($row = $dsql->GetArray('me'))
142  
143 {
144  
145 $addfile = $row['url'];
146  
147 $aid = $row['aid'];
148  
149 $dsql->ExecuteNoneQuery("Delete From `dede_uploads` where aid = '$aid' ");
150  
151 $upfile = $cfg_basedir.$addfile;
152  
153 if(@file_exists($upfile)) @unlink($upfile);
154  
155 }
156  
157 }
158  
159 $dsql->ExecuteNoneQuery("Delete From `dede_arctiny` where id='$aid'");
160  
161 if($addtable != '')
162  
163 {
164  
165 $dsql->ExecuteNoneQuery("Delete From `$addtable` where aid='$aid' ");
166  
167 }
168  
169 if($issystem != -1)
170  
171 {
172  
173 $dsql->ExecuteNoneQuery("Delete From `dede_archives` where id='$aid' ");
174  
175 }
176  
177 $dsql->ExecuteNoneQuery("Delete From `dede_feedback` where aid='$aid' ");
178  
179 $dsql->ExecuteNoneQuery("Delete From `dede_member_stow` where aid='$aid' ");
180  
181 $dsql->ExecuteNoneQuery("Delete From `dede_taglist` where aid='$aid' ");
182  
183 $dsql->ExecuteNoneQuery("Delete From `dede_erradd` where aid='$aid' ");
184  
185 }
186  
187 //刪除文本數(shù)據(jù)
188  
189 $filenameh = DEDEDATA."/textdata/".(ceil($aid/5000))."/{$aid}-".substr(md5($cfg_cookie_encode),0,16).".txt";
190  
191 if(@is_file($filenameh)) @unlink($filenameh);
192  
193 }
194  
195 if(empty($arcRow['money'])) $arcRow['money'] = 0;
196  
197 if(empty($arcRow['ismake'])) $arcRow['ismake'] = 1;
198  
199 if(empty($arcRow['arcrank'])) $arcRow['arcrank'] = 0;
200  
201 if(empty($arcRow['filename'])) $arcRow['filename'] = '';
202  
203 //刪除HTML
204  
205 if($arcRow['ismake']==-1 || $arcRow['arcrank']!=0 || $arcRow['typeid']==0 || $arcRow['money']>0)
206  
207 {
208  
209 return true;
210  
211 }
212  
213 //強(qiáng)制轉(zhuǎn)換非多站點模式,以便統(tǒng)一方式獲得實際HTML文件
214  
215 $GLOBALS['cfg_multi_site'] = 'N';
216  
217 $arcurl = GetFileUrl($arcRow['aid'],$arcRow['typeid'],$arcRow['senddate'],$arcRow['title'],$arcRow['ismake'],
218  
219 $arcRow['arcrank'],$arcRow['namerule'],$arcRow['typedir'],$arcRow['money'],$arcRow['filename']);
220  
221 if(!ereg("\?", $arcurl))
222  
223 {
224  
225 $htmlfile = GetTruePath().str_replace($GLOBALS['cfg_basehost'],'',$arcurl);
226  
227 if(file_exists($htmlfile) && !is_dir($htmlfile))
228  
229 {
230  
231 @unlink($htmlfile);
232  
233 $arcurls = explode(".", $htmlfile);
234  
235 $sname = $arcurls[count($arcurls)-1];
236  
237 $fname = ereg_replace("(\.$sname)$", "", $htmlfile);
238  
239 for($i=2; $i<=100; $i++)
240  
241 {
242  
243 $htmlfile = $fname."_{$i}.".$sname;
244  
245 if( @file_exists($htmlfile) ) @unlink($htmlfile);
246  
247 else break;
248  
249 }
250  
251 }
252  
253 }
254  
255 //解析Body中的資源,并刪除
256  
257 $willDelFiles = GetPicsTruePath($arcBodyRow['body'],$arcRow['litpic']);
258  
259 $nowtime = time();
260  
261 $executetime = MyDate('Y-m-d H:i:s',$nowtime);//獲得執(zhí)行時間
262  
263 $msg = "\r\n文章標(biāo)題:$arcRow[title]";
264  
265 WriteToDelFiles($msg);
266  
267 if(!empty($willDelFiles))
268  
269 {
270  
271 foreach($willDelFiles as $file)
272  
273 {
274  
275 if(file_exists($file) && !is_dir($file))
276  
277 {
278  
279 if(unlink($file)) $msg = "\r\n位置:$file\r\n結(jié)果:刪除成功!\r\n時間:$executetime";
280  
281 else $msg = "\r\n位置:$file\r\n結(jié)果:刪除失敗!\r\n時間:$executetime";
282  
283 }
284  
285 else $msg = "\r\n位置:$file\r\n結(jié)果:文件不存!\r\n時間:$executetime";
286  
287 WriteToDelFiles($msg);
288  
289 }//END foreach
290  
291 }
292  
293 else
294  
295 {
296  
297 $msg = "\r\n未在Body中解析到數(shù)據(jù)\r\nBody原始數(shù)據(jù):$arcBodyRow[body]\r\n時間:$executetime";
298  
299 WriteToDelFiles($msg);
300  
301 }
302  
303 return true;
304  
305 }
306  
307 //獲取真實路徑
308  
309 function GetTruePath($siterefer='', $sitepath='')
310  
311 {
312  
313 $truepath = $GLOBALS['cfg_basedir'];
314  
315 return $truepath;
316  
317 }
318  
319 ?>


到這里就結(jié)束了 ,很簡單吧, 我們再去試著刪除一篇文章 ,你會發(fā)現(xiàn)你刪除這篇文章以后,這篇文章的縮列圖和內(nèi)容上的圖片都同時刪除了!



收縮
  • 微信客服
  • 微信二維碼
  • 電話咨詢

  • 400-1100-266
校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
亚洲一区二区三区四区在线观看 | 色综合天天综合网天天狠天天| 亚州成人在线电影| 亚洲国产美女搞黄色| 亚洲一区在线观看网站| 亚洲一区二区中文在线| 亚洲与欧洲av电影| 日韩精品一级二级 | 国v精品久久久网| 粉嫩av亚洲一区二区图片| 粉嫩绯色av一区二区在线观看 | 337p粉嫩大胆噜噜噜噜噜91av| 日韩欧美国产精品| 久久久青草青青国产亚洲免观| 久久久久久亚洲综合| 国产女同互慰高潮91漫画| 久久久一区二区三区捆绑**| 国产欧美一区二区精品性| 中文字幕不卡一区| 亚洲精品五月天| 亚洲影院理伦片| 日本不卡在线视频| 国产在线一区二区综合免费视频| 国产精品88888| 一道本成人在线| 欧美精品国产精品| 日韩精品一区二区三区swag| 国产亚洲精品aa| 亚洲精品日日夜夜| 日本中文在线一区| 粉嫩aⅴ一区二区三区四区五区| 色综合天天在线| 欧美一级黄色录像| 国产精品美女久久久久高潮| 亚洲自拍都市欧美小说| 韩国成人在线视频| 91影院在线免费观看| 制服丝袜亚洲网站| 国产精品久久久爽爽爽麻豆色哟哟 | 色爱区综合激月婷婷| 91麻豆精品国产91久久久久| 日本一区二区三区视频视频| 亚洲与欧洲av电影| 国产丶欧美丶日本不卡视频| 色妞www精品视频| 精品国精品国产| 一区二区三区四区不卡在线| 日韩成人一区二区三区在线观看| 国产精品66部| 8v天堂国产在线一区二区| 国产欧美一区在线| 日本美女一区二区三区视频| 成人污视频在线观看| 欧美精品久久久久久久多人混战 | 91麻豆免费看片| 日韩精品中午字幕| 亚洲精品少妇30p| 国产精品99久久久久久似苏梦涵 | 国产精品视频免费看| 热久久免费视频| 色狠狠av一区二区三区| 久久老女人爱爱| 波多野结衣中文字幕一区| 精品视频在线看| 国产精品午夜在线| 久草这里只有精品视频| 欧美三级中文字幕在线观看| 国产精品免费免费| 久久国产夜色精品鲁鲁99| 色诱亚洲精品久久久久久| 国产清纯白嫩初高生在线观看91| 日产精品久久久久久久性色| 色综合久久久久久久久久久| 国产亚洲成aⅴ人片在线观看 | 在线成人午夜影院| 一区二区三区四区中文字幕| 成人动漫中文字幕| 国内精品伊人久久久久影院对白| 69p69国产精品| 亚洲一二三区视频在线观看| 亚洲综合久久av| 不卡欧美aaaaa| 国产三级一区二区三区| 美国一区二区三区在线播放| 欧美日韩精品欧美日韩精品一 | 麻豆精品视频在线观看视频| 欧美手机在线视频| 亚洲精品免费一二三区| 成+人+亚洲+综合天堂| 国产欧美日韩另类一区| 紧缚捆绑精品一区二区| 欧美变态tickling挠脚心| 亚洲国产wwwccc36天堂| 欧美性色黄大片手机版| 一区二区三区精品| 色婷婷综合激情| 亚洲六月丁香色婷婷综合久久| 成人国产精品免费| 国产精品美女一区二区在线观看| 国产乱子轮精品视频| 精品国产青草久久久久福利| 另类小说色综合网站| 精品精品国产高清一毛片一天堂| 麻豆精品新av中文字幕| 精品剧情v国产在线观看在线| 久久99精品久久久久婷婷| 成人视屏免费看| 国产精品久久久久久久岛一牛影视| 日韩精品免费视频人成| www.爱久久.com| ...中文天堂在线一区| 97se亚洲国产综合自在线| 亚洲天堂av一区| 欧美三级中文字幕在线观看| 爽好多水快深点欧美视频| 911精品产国品一二三产区| 琪琪一区二区三区| 精品电影一区二区三区| 成人午夜电影网站| 亚洲天堂av老司机| 在线免费观看成人短视频| 亚洲一区免费视频| 日韩欧美一级精品久久| 激情丁香综合五月| 中文字幕日韩一区| 欧美性一二三区| 久久99精品国产麻豆婷婷| 久久精品亚洲一区二区三区浴池| 国产成人精品一区二区三区四区| 综合久久综合久久| 欧美日本在线播放| 国产精品一区二区久久不卡| 国产精品灌醉下药二区| 欧美日韩一本到| 国产真实乱子伦精品视频| 亚洲欧美在线另类| 制服.丝袜.亚洲.中文.综合| 国产呦萝稀缺另类资源| 国产精品久久午夜| 欧美视频一区二区三区| 国产一区欧美日韩| 亚洲精品自拍动漫在线| 91精品国产综合久久国产大片| 韩国精品在线观看| 亚洲精品视频自拍| 日韩精品中文字幕一区| aaa亚洲精品| 奇米影视在线99精品| 国产精品私房写真福利视频| 欧美亚洲另类激情小说| 国产精品一区在线观看你懂的| 夜色激情一区二区| 久久久99精品免费观看不卡| 欧美色偷偷大香| 懂色av中文字幕一区二区三区 | 激情文学综合网| 一区二区在线免费观看| 精品国产欧美一区二区| 91国在线观看| 国产91富婆露脸刺激对白| 香蕉成人伊视频在线观看| 国产精品国产馆在线真实露脸| 欧美一区二区三区四区在线观看| 91在线视频免费91| 国产一区高清在线| 视频一区中文字幕| 有坂深雪av一区二区精品| 久久精品亚洲国产奇米99| 91精品免费观看| 91国偷自产一区二区开放时间| 国产成人精品午夜视频免费| 天天操天天干天天综合网| 亚洲丝袜自拍清纯另类| 久久久亚洲精品一区二区三区 | 日韩欧美电影在线| 欧美性videosxxxxx| 福利一区二区在线| 精品一区二区三区免费| 日日夜夜免费精品视频| 亚洲资源中文字幕| 亚洲色图欧洲色图| 日本一区二区不卡视频| 精品国产免费一区二区三区香蕉| 欧美电影影音先锋| 欧美日韩国产中文| 欧美在线观看视频一区二区| 成人黄色国产精品网站大全在线免费观看| 久久66热偷产精品| 久久精品国产成人一区二区三区| 日韩精彩视频在线观看| 午夜视频在线观看一区二区三区| 亚洲裸体在线观看| 亚洲色图第一区| 中文字幕永久在线不卡| 国产精品传媒在线| 国产精品天天看| 日本一区二区三区电影| 国产日韩欧美精品一区| 久久精品在线观看| 久久久久久久久久久久久夜|