發(fā)布時間:2020-07-14
欄目:帝國新聞
我是個茉鳥有所提升,在尋求建站系統(tǒng)時聽得進,找到了傳說中靈活度最高,最好用的網(wǎng)站管理系統(tǒng)先進水平,也就是我要說的帝國cms便利性,于是下載了個EmpireCMS v 6.0來研究一下,在學(xué)習(xí)帝國CMS的過程中重要平臺,側(cè)重了解了一下帝國的工作原理深刻認識,大量的函數(shù),耗了我?guī)滋鞎r間才理清楚個來龍去脈應用提升。不經(jīng)意間主動性,發(fā)現(xiàn)一個疑是帝國CMS的bug,這個BUG不大不小發展的關鍵,對平時的使用基本沒什么影響道路,也就是在刪除數(shù)據(jù)表的時候可能遇到。下面我就放出來吧真諦所在,讓高手們進一步確認(rèn)指導。
在/e/class/moddofun.php中有個刪除副表分表函數(shù)
function DelDataTable($add,$userid,$username){
global $empire,$dbtbpre帝國cms軟件采集,$emod_r;
//操作權(quán)限
CheckLevel($userid,$username,$classid,"table");
$tid=(int)$add['tid'];
$tbname=RepPostVar($add['tbname']);
$datatb=(int)$add['datatb'];
if(!$tid||!$tbname||!$datatb)
{
printerror("NotChangeDataTable","history.go(-1)");
}
$tr=$empire->fetch1("select tid,tbname,datatbs,deftb from {$dbtbpre}enewstable where tid='$tid'");
if(!$tr['tid'])
{
printerror("NotChangeDataTable","history.go(-1)");
}
if(!strstr($tr['datatbs'],','.$datatb.'帝國cms采集軟件,'))
{
printerror("NotChangeDataTable","history.go(-1)");
}
帝國cms批量助手if($tr['deftb']==$datatb||$datatb==1)
{
printerror("NotDelDefDataTable","history.go(-1)");
}
$newdatatbs=str_replace(','.$datatb.',',',',$tr['datatbs']);
$sql=$empire->query("update {$dbtbpre}enewstable set datatbs='$newdatatbs' where tid='$tid'");
//刪除信息
$infosql=$empire->query("select * from {$dbtbpre}ecms_".$tr[tbname]." where stb='$datatb'");
帝國cms批量更新文章while($infor=$empire->fetch($infosql))
{
$mid=$emod_r[$infor[classid]]['modid'];
$pf=$emod_r[$mid]['pagef'];
$stf=$emod_r[$mid]['savetxtf'];
//分頁字段
if($pf)
{
if(strstr($emod_r[$mid]['tbdataf'],','.$pf.','))
{
$finfor=$empire->fetch1("select ".$pf." from {$dbtbpre}ecms_".$tr[tbname]."_data_".$datatb." where id='$infor[id]'");
$infor[$pf]=$finfor[$pf];
}
}
//存文本
if($stf)
{
$newstextfile=$infor[$stf];
$infor[$stf]=GetTxtFieldText($infor[$stf]);
DelTxtFieldText($newstextfile);//刪除文件
}
//刪除信息文件
DelNewsFile($infor[filename],$infor[newspath],$infor[classid],$infor[$pf],$infor[groupid]);
//刪除其它表記錄
$empire->query("delete from {$dbtbpre}enewsqf where id='$infor[id]' and classid='$infor[classid]'");
$empire->query("delete from {$dbtbpre}enewsinfovote where id='$infor[id]' and classid='$infor[classid]'");
$empire->query("delete from {$dbtbpre}enewsdiggips where id='$infor[id]' and classid='$infor[classid]'");
//刪除附件
DelNewsTheFile($infor['id'],$infor['classid']);
}
$deltb=$empire->query("delete from {$dbtbpre}ecms_".$tr[tbname]." where stb='$datatb'");
//刪除表
$deltb=$empire->query("DROP TABLE IF EXISTS {$dbtbpre}ecms_".$tr[tbname]."_data_".$datatb.";");
GetConfig(1);//更新緩存
if($sql)
{
//操作日志
insert_dolog("tid=".$tid."
tbname=".$tr[tbname]."&datatb=$datatb");
printerror("DelDataTableSuccess"帝國cms批量添加產(chǎn)品 ,"db/ListDataTable.php?tid=$tid&tbname=$tr[tbname]");
}
else
{
printerror("DbError","history.go(-1)");
}
}
巴比站長
紅色部分,作者的意思應(yīng)該是從模型緩存數(shù)組里獲取當(dāng)前要操作的欄目對應(yīng)的模型ID充分,但本人通過輸出emod_r的全部內(nèi)容進一步完善,發(fā)現(xiàn)這個數(shù)組里并沒有以模型ID(modid元素),而其第一維下標(biāo)應(yīng)該是模板ID(newstempid)競爭力,這條語句取出的mid可能是錯誤的調整推進。那么后續(xù)操作要么誤操作帝國cms批量更新,要么失敗兩個角度入手。我翻開當(dāng)時學(xué)習(xí)時的記錄(現(xiàn)在已經(jīng)記得不清楚了)建強保護,寫了個替代的語句。
文章地址:http://cdgoodok.com/article/diguo/ysdgCMSEmpireCMSvzxBUG.html