ListAllInfo.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. <?php
  2. define('EmpireCMSAdmin','1');
  3. require('../class/connect.php');
  4. require('../class/db_sql.php');
  5. require('../class/functions.php');
  6. require LoadLang("pub/fun.php");
  7. require("../data/dbcache/class.php");
  8. $link=db_connect();
  9. $empire=new mysqlquery();
  10. //验证用户
  11. $lur=is_login();
  12. $logininid=$lur['userid'];
  13. $loginin=$lur['username'];
  14. $loginrnd=$lur['rnd'];
  15. $loginlevel=$lur['groupid'];
  16. $loginadminstyleid=$lur['adminstyleid'];
  17. //ehash
  18. $ecms_hashur=hReturnEcmsHashStrAll();
  19. //取得数据表
  20. $tid=(int)$public_r['tid'];
  21. $tbname=$_GET['tbname']?$_GET['tbname']:$public_r['tbname'];
  22. $tbname=RepPostVar($tbname);
  23. $changetbs='';
  24. $havetb=0;
  25. $tbsql=$empire->query("select tid,tbname,tname from {$dbtbpre}enewstable order by tid");
  26. while($tbr=$empire->fetch($tbsql))
  27. {
  28. $selected='';
  29. if($tbname==$tbr[tbname])
  30. {
  31. $tid=$tbr[tid];
  32. $selected=' selected';
  33. $havetb=1;
  34. }
  35. $changetbs.="<option value='".$tbr[tbname]."'".$selected.">".$tbr[tname]."(".$tbr[tbname].")</option>";
  36. }
  37. if($havetb==0)
  38. {
  39. printerror('ErrorUrl','');
  40. }
  41. //取得相应的信息
  42. $user_r=$empire->fetch1("select groupid,adminclass from {$dbtbpre}enewsuser where userid='$logininid'");
  43. //取得用户组
  44. $gr=$empire->fetch1("select doall,doselfinfo from {$dbtbpre}enewsgroup where groupid='$user_r[groupid]'");
  45. //管理员
  46. $where='';
  47. $and='';
  48. $ewhere='';
  49. $search="&tbname=$tbname".$ecms_hashur['ehref'];
  50. $ecmscheck=(int)$_GET['ecmscheck'];
  51. $addecmscheck='';
  52. $indexchecked=1;
  53. if($ecmscheck)
  54. {
  55. $search.='&ecmscheck='.$ecmscheck;
  56. $addecmscheck='&ecmscheck='.$ecmscheck;
  57. $indexchecked=0;
  58. }
  59. $infotb=ReturnInfoMainTbname($tbname,$indexchecked);
  60. //优化
  61. $modid=$etable_r[$tbname][mid];
  62. $yhadd='';
  63. $yhvar='hlist';
  64. $yhid=$etable_r[$tbname][yhid];
  65. if($yhid)
  66. {
  67. $yhadd=ReturnYhSql($yhid,$yhvar);
  68. if($yhadd)
  69. {
  70. $and=$where?' and ':' where ';
  71. $where.=$and.$yhadd;
  72. }
  73. }
  74. if(empty($yhadd))
  75. {
  76. //时间范围
  77. $infolday=(int)$_GET['infolday'];
  78. if(empty($infolday))
  79. {
  80. $infolday=$public_r['infolday'];
  81. }
  82. if($infolday&&$infolday!=1)
  83. {
  84. $ckinfolday=time()-$infolday;
  85. $and=$where?' and ':' where ';
  86. $where.=$and."newstime>'$ckinfolday'";
  87. $search.="&infolday=$infolday";
  88. }
  89. if($infolday==1)
  90. {
  91. $search.="&infolday=$infolday";
  92. }
  93. }
  94. if(!$gr['doall'])
  95. {
  96. $cids='';
  97. $a=explode("|",$user_r['adminclass']);
  98. for($i=1;$i<count($a)-1;$i++)
  99. {
  100. $dh=',';
  101. if(empty($cids))
  102. {
  103. $dh='';
  104. }
  105. $cids.=$dh.$a[$i];
  106. }
  107. if($cids=='')
  108. {
  109. $cids=0;
  110. }
  111. $and=$where?' and ':' where ';
  112. $where.=$and.'classid in ('.$cids.')';
  113. }
  114. //只能编辑自己的信息
  115. if($gr['doselfinfo'])
  116. {
  117. $and=$where?' and ':' where ';
  118. $where.=$and."userid='$logininid' and ismember=0";
  119. }
  120. $url="<a href=ListAllInfo.php?tbname=".$tbname.$addecmscheck.$ecms_hashur['ehref'].">管理信息</a>";
  121. $start=0;
  122. $page=(int)$_GET['page'];
  123. $page=RepPIntvar($page);
  124. $line=intval($public_r['hlistinfonum']);//每页显示
  125. $page_line=21;
  126. $offset=$page*$line;
  127. //栏目ID
  128. $classid=intval($_GET['classid']);
  129. if($classid)
  130. {
  131. $and=$where?' and ':' where ';
  132. if($class_r[$classid][islast])
  133. {
  134. $where.=$and."classid='$classid'";
  135. }
  136. else
  137. {
  138. $where.=$and."(".ReturnClass($class_r[$classid][sonclass]).")";
  139. }
  140. $search.="&classid=$classid";
  141. }
  142. //模型
  143. $infomod_r=$empire->fetch1("select mid,listfile from {$dbtbpre}enewsmod where mid='$modid'");
  144. //标题分类
  145. $ttid=(int)$_GET['ttid'];
  146. if($ttid)
  147. {
  148. $and=$where?' and ':' where ';
  149. $where.=$and."ttid='$ttid'";
  150. $search.="&ttid=$ttid";
  151. }
  152. //标题分类
  153. $tts='';
  154. $ttsql=$empire->query("select typeid,tname from {$dbtbpre}enewsinfotype where mid='$infomod_r[mid]' order by myorder");
  155. while($ttr=$empire->fetch($ttsql))
  156. {
  157. $select='';
  158. if($ttr[typeid]==$ttid)
  159. {
  160. $select=' selected';
  161. }
  162. $tts.="<option value='$ttr[typeid]'".$select.">$ttr[tname]</option>";
  163. }
  164. $stts=$tts?"<select name='ttid'><option value='0'>标题分类</option>$tts</select>":"";
  165. //搜索
  166. $showisgood=(int)$_GET['showisgood'];
  167. $showfirsttitle=(int)$_GET['showfirsttitle'];
  168. $sear=(int)$_GET['sear'];
  169. if($sear)
  170. {
  171. $and=$where?' and ':' where ';
  172. $showspecial=(int)$_GET['showspecial'];
  173. if($showspecial==1)//置顶
  174. {
  175. $where.=$and.'istop>0';
  176. }
  177. elseif($showspecial==2)//推荐
  178. {
  179. $where.=$and.'isgood>0';
  180. }
  181. elseif($showspecial==3)//头条
  182. {
  183. $where.=$and.'firsttitle>0';
  184. }
  185. elseif($showspecial==5)//签发
  186. {
  187. $where.=$and.'isqf=1';
  188. }
  189. elseif($showspecial==7)//投稿
  190. {
  191. $where.=$and.'ismember=1';
  192. }
  193. elseif($showspecial==8)//我的信息
  194. {
  195. $where.=$and."userid='$logininid' and ismember=0";
  196. }
  197. $and=$where?' and ':' where ';
  198. //推荐
  199. if($showisgood)
  200. {
  201. if($showisgood>0)
  202. {
  203. $where.=$and."isgood='$showisgood'";
  204. }
  205. else
  206. {
  207. $where.=$and.'isgood>0';
  208. }
  209. }
  210. $and=$where?' and ':' where ';
  211. //头条
  212. if($showfirsttitle)
  213. {
  214. if($showfirsttitle>0)
  215. {
  216. $where.=$and."firsttitle='$showfirsttitle'";
  217. }
  218. else
  219. {
  220. $where.=$and.'firsttitle>0';
  221. }
  222. }
  223. $and=$where?' and ':' where ';
  224. if($_GET['keyboard'])
  225. {
  226. $keyboard=RepPostVar2($_GET['keyboard']);
  227. $show=RepPostStr($_GET['show'],1);
  228. if($show==0)//搜索全部
  229. {
  230. $where.=$and."(title like '%$keyboard%' or username like '%$keyboard%' or id='$keyboard' or keyboard like '%$keyboard%')";
  231. }
  232. elseif($show==1)//搜索标题
  233. {
  234. $where.=$and."(title like '%$keyboard%')";
  235. }
  236. elseif($show==3)//ID
  237. {
  238. $where.=$and."(id='$keyboard')";
  239. }
  240. elseif($show==4)//搜索关键字
  241. {
  242. $where.=$and."(keyboard like '%$keyboard%')";
  243. }
  244. else
  245. {
  246. $where.=$and."(username like '%$keyboard%')";
  247. }
  248. }
  249. $search.="&sear=1&keyboard=$keyboard&show=$show&showspecial=$showspecial&showisgood=$showisgood&showfirsttitle=$showfirsttitle";
  250. }
  251. //显示重复标题
  252. if($_GET['showretitle']==1)
  253. {
  254. $and=$where?' and ':' where ';
  255. $search.="&showretitle=1&srt=".intval($_GET['srt']);
  256. $addsrt="";
  257. $srtid="";
  258. $first=1;
  259. $srtsql=$empire->query("select id,title from ".$infotb." group by title having(count(*))>1");
  260. while($srtr=$empire->fetch($srtsql))
  261. {
  262. if($first==1)
  263. {
  264. $addsrt.="title='".addslashes($srtr['title'])."'";
  265. $srtid.=$srtr['id'];
  266. $first=0;
  267. }
  268. else
  269. {
  270. $addsrt.=" or title='".addslashes($srtr['title'])."'";
  271. $srtid.=",".$srtr['id'];
  272. }
  273. }
  274. if(!empty($addsrt))
  275. {
  276. if($_GET['srt']==1)
  277. {
  278. $where.=$and."(".$addsrt.") and id not in (".$srtid.")";
  279. }
  280. else
  281. {
  282. $where.=$and."(".$addsrt.")";
  283. }
  284. }
  285. else
  286. {
  287. printerror("HaveNotReInfo","ListAllInfo.php?tbname=".$tbname.$addecmscheck.$ecms_hashur['ehref']);
  288. }
  289. }
  290. //排序
  291. $orderby=RepPostStr($_GET['orderby'],1);
  292. $doorderby=$orderby?'asc':'desc';
  293. $myorder=RepPostStr($_GET['myorder'],1);
  294. if($myorder==1)//ID号
  295. {$doorder="id";}
  296. elseif($myorder==2)//时间
  297. {$doorder="newstime";}
  298. elseif($myorder==5)//评论数
  299. {$doorder="plnum";}
  300. elseif($myorder==3)//人气
  301. {$doorder="onclick";}
  302. elseif($myorder==4)//下载
  303. {$doorder="totaldown";}
  304. else//默认排序
  305. {$doorder="id";}
  306. $doorder.=' '.$doorderby;
  307. $search.="&myorder=$myorder&orderby=$orderby";
  308. $totalquery="select count(*) as total from ".$infotb.$where;
  309. //表信息数
  310. $tbinfos=eGetTableRowNum("{$dbtbpre}ecms_".$tbname);
  311. $tbckinfos=eGetTableRowNum("{$dbtbpre}ecms_".$tbname."_check");
  312. //取得总条数
  313. $totalnum=intval($_GET['totalnum']);
  314. if($totalnum<1)
  315. {
  316. if(empty($where))
  317. {
  318. $num=$indexchecked==1?$tbinfos:$tbckinfos;
  319. }
  320. else
  321. {
  322. $num=$empire->gettotal($totalquery);
  323. }
  324. }
  325. else
  326. {
  327. $num=$totalnum;
  328. }
  329. $search1=$search;
  330. $search.="&totalnum=$num";
  331. $returnpage=page2($num,$line,$page_line,$start,$page,$search);
  332. $phpmyself=urlencode(eReturnSelfPage(1));
  333. //导入页面
  334. $deftempfile=ECMS_PATH.'e/data/html/list/alllistinfo.php';
  335. if($infomod_r[listfile])
  336. {
  337. $tempfile=ECMS_PATH.'e/data/html/list/all'.$infomod_r[listfile].'.php';
  338. if(!file_exists($tempfile))
  339. {
  340. $tempfile=$deftempfile;
  341. }
  342. }
  343. else
  344. {
  345. $tempfile=$deftempfile;
  346. }
  347. require($tempfile);
  348. db_close();
  349. $empire=null;
  350. ?>