-
金屬工藝品加工廠家類網(wǎng)...
-
商用貨架展架類網(wǎng)站織夢(mèng)...
-
旅游公司類網(wǎng)站織夢(mèng)模板...
-
壓濾機(jī)過濾設(shè)備類網(wǎng)站織...
-
大理石瓷磚生產(chǎn)類網(wǎng)站織...
-
中英雙語建材瓷磚裝飾類...
-
蔬菜水果批發(fā)類網(wǎng)站織夢(mèng)...
-
網(wǎng)站優(yōu)化快速排名類科技...
-
齒輪設(shè)備類網(wǎng)站織夢(mèng)模板...
-
電子產(chǎn)品營(yíng)銷類網(wǎng)站織夢(mèng)...
-
花卉養(yǎng)殖資訊類網(wǎng)站織夢(mèng)...
-
玻璃制品廠家類網(wǎng)站織夢(mèng)...
-
重工業(yè)機(jī)械鋼鐵類網(wǎng)站織...
-
汽車音箱喇叭低音炮類網(wǎng)...
-
戀愛情感資訊類網(wǎng)站織夢(mèng)...
-
創(chuàng)業(yè)資訊博客教程類網(wǎng)站...
-
汽車銷售縱覽類網(wǎng)站織夢(mèng)...
-
財(cái)富管理培訓(xùn)咨詢類網(wǎng)站...
-
家禽飼養(yǎng)基地類網(wǎng)站織夢(mèng)...
-
室內(nèi)設(shè)計(jì)裝修工程類網(wǎng)站...
在用織夢(mèng)建站的時(shí)候,我們時(shí)常會(huì)刪除一些文章或者上傳一些沒用的圖片,但是有個(gè)問題,就是刪除文章的同時(shí),文章內(nèi)的圖片還保存在網(wǎng)站空間中,占用了服務(wù)器資源。我曾經(jīng)就有過一次,無用的圖片達(dá)到八百多MB,要是手動(dòng)去刪,何年何月啊。
一般來說有二種情況,我們分別來操作:
- 1、刪除文章的同時(shí),刪除該文章內(nèi)的圖片,
打開dede/inc/inc_batchup.php
找到
"//刪除數(shù)據(jù)庫的內(nèi)容"
在這前面加上
//刪除縮略圖if($arcRow['litpic']!=""){$dsql->ExecuteNoneQuery("Delete From dede_uploads where url='$arcRow[litpic]'");$truedir = GetTruePath($arcRow['siterefer'],$arcRow['sitepath']);$litpicfile = $truedir.$arcRow['litpic'];@unlink($litpicfile);}//刪除大圖$arcbodyQuery = "Select * from ".$arcRow['addtable']." where aid='$aid'";$arcbodyRow = $dsql->GetOne($arcbodyQuery);$imgsrcarray=GetImageSrc($arcbodyRow['body']);foreach ($imgsrcarray as $v) {if((trim($v)!="")&&(!eregi("^http://",$v))){$dsql->ExecuteNoneQuery("Delete From dede_uploads where url='$v'");$picfile = $truedir.$v;@unlink($picfile);}}//刪除數(shù)據(jù)庫的內(nèi)容
再找到
Select dede_archives.ID,dede_archives.title,dede_archives.typeid
改成
Select dede_archives.ID,dede_archives.title,dede_archives.typeid,dede_archives.litpic
在文件最后加上一函數(shù)
//獲得內(nèi)容中的圖像地址function GetImageSrc($body){if( !isset($body)) return '';else{preg_match_all ("/<(img|IMG)(.*)(src|SRC)=[\"|'|]{0,}([h|\/].*(jpg|JPG|gif|GIF))[\"|'|\s]{0,}/isU",$body,$out);return $out[4];}}
- 2、那就是很早之前刪除了很多文章,當(dāng)時(shí)并沒有完成第一種情況時(shí)的修改, 意思就是明知道空間中有多余的圖片。
找到后臺(tái)路徑中的
dede/templets/content_batch_up.htm
找到下面代碼:
<inputclass="np"type="radio"checked="checked"name="action"value="modddpic"/><br />更正縮圖錯(cuò)誤<br /><inputclass="np"type="radio"name="action"value="delerrdata"/><br />清空錯(cuò)誤的文檔數(shù)據(jù)</td>
改成
<inputclass="np"type="radio"checked="checked"name="action"value="modddpic"/><br />更正縮圖錯(cuò)誤<br /> <inputclass="np"type="radio"name="action"value="delerrdata"/><br />清空錯(cuò)誤的文檔數(shù)據(jù)<br /> <inputclass="np"type="radio"name="action"value="delerrpic"/><br />清空錯(cuò)誤的圖片</td>
找到
dede/content_batchup_actionphp
在最底部加入下面代碼
elseif($action == 'delerrpic'){$file_a=array();function rFile($p){global $file_a;$handle=opendir($p);$dir_a=array();while ($file = readdir($handle)) {if($file!="." && $file!=".."){$tmp=$p."/".$file;if(is_dir($tmp)){$dir_a[count($dir_a)]=$tmp;}elseif(is_file($tmp)){$file_a[count($file_a)]=$tmp;}}}closedir($handle);foreach($dir_a as $v){rFile($v);}}rFile("../uploads/allimg");//調(diào)用,要遍歷的目錄foreach($file_a as $v){$temp=substr($v,2);$query = "select count(*) from dede_addonarticle where body like '%".$temp."%'";$dsql->setquery($query);$dsql->execute();while($row = $dsql->getarray()){if($row[0]==0){if(substr($v, -8, 4)!="_lit" && substr($v, -10, 5)!="index"){if(file_exists($v))unlink($v);}}}}$dsql->Close();ShowMsg("成功清除錯(cuò)誤圖片!","javascript:;");exit();}


