返回頂部
關閉軟件導航
位置:首頁 > 資訊 > 帝國新聞>疑是帝國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
解放雙手無盡可能,有問題添加天線貓微信
主站蜘蛛池模板: 无码尹人久久相蕉无码| 亚洲AV永久无码精品水牛影视| 伊人蕉久中文字幕无码专区| 日韩精品无码免费一区二区三区| 亚洲桃色AV无码| 精品日韩亚洲AV无码| 国产精品国产免费无码专区不卡| 亚洲国产精品无码专区影院 | 色爱无码AV综合区| 亚洲AV日韩AV无码污污网站| 国产精品无码一二区免费| 一本大道东京热无码一区| 日韩电影无码A不卡| 色综合无码AV网站| 精品久久久无码人妻中文字幕豆芽 | 深夜a级毛片免费无码| 日韩av无码一区二区三区| 无码人妻一区二区三区免费视频 | 影音先锋无码a∨男人资源站| 久久久久无码精品亚洲日韩| YY111111少妇无码理论片| 无码 免费 国产在线观看91| 丰满熟妇人妻Av无码区| 亚洲精品无码久久毛片| 一本一道VS无码中文字幕| 特级毛片内射www无码| 无码137片内射在线影院| 国产成人精品无码播放| a级毛片无码免费真人久久| 亚洲AV无码乱码在线观看富二代 | 综合国产在线观看无码| 无码人妻一区二区三区精品视频| 波多野结衣VA无码中文字幕电影| 亚洲∧v久久久无码精品| 免费无码一区二区三区蜜桃| 黄色成人网站免费无码av| 亚洲日韩中文字幕无码一区| 18禁无遮拦无码国产在线播放| 黑人巨大无码中文字幕无码| 在人线av无码免费高潮喷水| 亚洲AV无码无限在线观看不卡|