發(fā)布時間:2021-02-27
欄目:其他
我是個茉鳥免費代理ip驗證工具 各領域,在尋求建站系統(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,$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.','))
{
printerror("NotChangeDataTable","history.go(-1)");
}
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'");
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","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ù)操作要么誤操作設計能力,要么失敗品牌。我翻開當(dāng)時學(xué)習(xí)時的記錄(現(xiàn)在已經(jīng)記得不清楚了)深入開展,寫了個替代的語句。
上一篇:MySQL官方源從8.0.3直接yum升級到8.0.4后無法啟動
下一篇:北京衛(wèi)生監(jiān)督所收集網(wǎng)絡(luò)醫(yī)托證據(jù) 將聯(lián)合多部門調(diào)查
文章地址:http://cdgoodok.com/article/other/ysdgCMSEmpireCMSvzxBUG.html