返回頂部
關閉軟件導航
位置:首頁 > 資訊 > 帝國新聞>疑是帝國CMS(EmpireCMS v 6.0)最新BUG

  我是個茉鳥,在尋求建站系統時,找到了傳說中靈活度最高,最好用的網站管理系統,也就是我要說的帝國cms,于是下載了個EmpireCMS v 6.0來研究一下,在學習帝國CMS的過程中,側重了解了一下帝國的工作原理,大量的函數,耗了我幾天時間才理清楚個來龍去脈。不經意間,發現一個疑是帝國CMS的bug,這個BUG不大不小,對平時的使用基本沒什么影響,也就是在刪除數據表的時候可能遇到。下面我就放出來吧,讓高手們進一步確認。

  在/e/class/moddofun.php中有個刪除副表分表函數

  function DelDataTable($add,$userid,$username){

  global $empire,$dbtbpre帝國cms軟件采集,$emod_r;

  //操作權限

  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批量添加產品 ,"db/ListDataTable.php?tid=$tid&tbname=$tr[tbname]");

  }

  else

  {

  printerror("DbError","history.go(-1)");

  }

  }

  巴比站長

  紅色部分,作者的意思應該是從模型緩存數組里獲取當前要操作的欄目對應的模型ID,但本人通過輸出emod_r的全部內容,發現這個數組里并沒有以模型ID(modid元素),而其第一維下標應該是模板ID(newstempid),這條語句取出的mid可能是錯誤的。那么后續操作要么誤操作帝國cms批量更新,要么失敗。我翻開當時學習時的記錄(現在已經記得不清楚了),寫了個替代的語句。

如果您覺得 疑是帝國CMS(EmpireCMS v 6.0)最新BUG 這篇文章對您有用,請分享給您的好友,謝謝
文章地址:http://www.meyanliao.com/article/diguo/ysdgCMSEmpireCMSvzxBUG.html
解放雙手無盡可能,有問題添加天線貓微信
主站蜘蛛池模板: 国产a v无码专区亚洲av| 伊人久久大香线蕉无码麻豆| 蕾丝av无码专区在线观看| 亚洲av无码有乱码在线观看| 粉嫩大学生无套内射无码卡视频| 亚洲中文字幕久久精品无码2021| 国产无码网页在线观看| 亚洲自偷自偷偷色无码中文| 国产成人无码AV在线播放无广告| 国产成人精品无码免费看| 无码av不卡一区二区三区| 中文字幕无码不卡免费视频 | 中文字幕精品无码一区二区三区| 亚洲AV色吊丝无码| 亚洲AV无码成人精品区蜜桃| 国产色无码精品视频国产| 亚洲爆乳精品无码一区二区| 日韩丰满少妇无码内射| 亚洲av无码乱码国产精品| 亚洲 另类 无码 在线| 久久久国产精品无码一区二区三区 | 无码视频一区二区三区| 亚洲午夜无码毛片av久久京东热| 色欲A∨无码蜜臀AV免费播| 一级毛片中出无码| 精品亚洲成α人无码成α在线观看 | 少妇精品无码一区二区三区| 亚洲午夜国产精品无码| 中文有码vs无码人妻| 国产成人无码a区在线视频| 永久无码精品三区在线4| 成人无码精品一区二区三区| 亚洲午夜成人精品无码色欲| 秋霞鲁丝片Av无码少妇| 少妇精品无码一区二区三区| 久久国产精品无码一区二区三区 | 日韩av片无码一区二区不卡电影| 亚洲日韩中文字幕无码一区| 免费无码又爽又刺激聊天APP | 精品久久久无码人妻字幂| 成在人线AV无码免费|