ListNews.php 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  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. $classid = (int)$_GET['classid'];
  20. $bclassid = (int)$class_r[$classid]['bclassid'];
  21. //取得栏目名
  22. if (!$class_r[$classid][classid] || !$class_r[$classid][tbname]) {
  23. printerror('ErrorUrl', 'history.go(-1)');
  24. }
  25. //栏目
  26. $thiscr = $empire->fetch1("select tbname,listorder,allinfos,infos from {$dbtbpre}enewsclass where classid='$classid'");
  27. if (!$thiscr['tbname']) {
  28. printerror('ErrorUrl', 'history.go(-1)');
  29. }
  30. $classallinfos = $thiscr['allinfos'];
  31. $classinfos = $thiscr['infos'];
  32. $classckinfos = $classallinfos - $classinfos;
  33. //验证权限
  34. $doselfinfo = CheckLevel($logininid, $loginin, $classid, "news");
  35. //取得模型表
  36. $fieldexp = "<!--field--->";
  37. $recordexp = "<!--record-->";
  38. //返回搜索字段列表
  39. function ReturnSearchOptions($enter, $field, $record)
  40. {
  41. global $modid, $emod_r;
  42. $r = explode($record, $enter);
  43. $count = count($r) - 1;
  44. for ($i = 0; $i < $count; $i++) {
  45. if (!$sr['searchallfield']) {
  46. $or = "";
  47. } else {
  48. $or = " or ";
  49. }
  50. $r1 = explode($field, $r[$i]);
  51. if ($r1[1] == "special.field" || strstr($emod_r[$modid]['tbdataf'], ',' . $r1[1] . ',')) {
  52. continue;
  53. }
  54. if ($r1[1] == "id") {
  55. $sr['searchallfield'] .= $or . $r1[1] . "='[!--key--]'";
  56. $sr['select'] .= "<option value=\"" . $r1[1] . "\">" . $r1[0] . "</option>";
  57. continue;
  58. }
  59. $sr['searchallfield'] .= $or . $r1[1] . " like '%[!--key--]%'";
  60. $sr['select'] .= "<option value=\"" . $r1[1] . "\">" . $r1[0] . "</option>";
  61. }
  62. return $sr;
  63. }
  64. $modid = (int)$class_r[$classid][modid];
  65. $infomod_r = $empire->fetch1("select enter,tbname,sonclass,listfile from {$dbtbpre}enewsmod where mid=" . $modid);
  66. if (empty($infomod_r['tbname'])) {
  67. printerror("ErrorUrl", "history.go(-1)");
  68. }
  69. $infomod_r['enter'] .= '发布者<!--field--->username<!--record-->ID<!--field--->id<!--record-->关键字<!--field--->keyboard<!--record-->';
  70. $searchoptions_r = ReturnSearchOptions($infomod_r['enter'], $fieldexp, $recordexp);
  71. //审核表
  72. $search = '';
  73. $search .= $ecms_hashur['ehref'];
  74. $addecmscheck = '';
  75. $ecmscheck = (int)$_GET['ecmscheck'];
  76. $indexchecked = 1;
  77. if ($ecmscheck) {
  78. $search .= '&ecmscheck=' . $ecmscheck;
  79. $addecmscheck = '&ecmscheck=' . $ecmscheck;
  80. $indexchecked = 0;
  81. }
  82. $infotb = ReturnInfoMainTbname($class_r[$classid]['tbname'], $indexchecked);
  83. //导航
  84. $url = AdminReturnClassLink($classid) . '&nbsp;>&nbsp;信息列表';
  85. $start = 0;
  86. $page = (int)$_GET['page'];
  87. $page = RepPIntvar($page);
  88. $line = intval($public_r['hlistinfonum']);//每页显示
  89. $page_line = 12;
  90. $offset = $page * $line;
  91. $search .= "&bclassid=$bclassid&classid=$classid";
  92. $add = '';
  93. $ewhere = '';
  94. //搜索
  95. $showisgood = (int)$_GET['showisgood'];
  96. $showfirsttitle = (int)$_GET['showfirsttitle'];
  97. $sear = (int)$_GET['sear'];
  98. if ($sear) {
  99. $keyboard = RepPostVar2($_GET['keyboard']);
  100. $show = RepPostVar($_GET['show']);
  101. //关键字
  102. if ($keyboard) {
  103. //搜索全部
  104. if (!$show) {
  105. $add = " and (" . str_replace("[!--key--]", $keyboard, $searchoptions_r['searchallfield']) . ")";
  106. } //搜索字段
  107. elseif ($show && strstr($infomod_r['enter'], "<!--field--->" . $show . "<!--record-->")) {
  108. $add = $show != "id" ? " and (" . $show . " like '%$keyboard%')" : " and (" . $show . "='$keyboard')";
  109. $searchoptions_r['select'] = str_replace(" value=\"" . $show . "\">", " value=\"" . $show . "\" selected>", $searchoptions_r['select']);
  110. }
  111. }
  112. //特殊属性
  113. $showspecial = (int)$_GET['showspecial'];
  114. if ($showspecial == 1)//置顶
  115. {
  116. $add .= ' and istop>0';
  117. } elseif ($showspecial == 2)//推荐
  118. {
  119. $add .= ' and isgood>0';
  120. } elseif ($showspecial == 3)//头条
  121. {
  122. $add .= ' and firsttitle>0';
  123. } elseif ($showspecial == 5)//签发
  124. {
  125. $add .= ' and isqf=1';
  126. } elseif ($showspecial == 7)//投稿
  127. {
  128. $add .= ' and ismember=1';
  129. } elseif ($showspecial == 8)//我的信息
  130. {
  131. $add .= " and userid='$logininid' and ismember=0";
  132. }
  133. //推荐
  134. if ($showisgood) {
  135. if ($showisgood > 0) {
  136. $add .= " and isgood='$showisgood'";
  137. } else {
  138. $add .= ' and isgood>0';
  139. }
  140. }
  141. //头条
  142. if ($showfirsttitle) {
  143. if ($showfirsttitle > 0) {
  144. $add .= " and firsttitle='$showfirsttitle'";
  145. } else {
  146. $add .= ' and firsttitle>0';
  147. }
  148. }
  149. //标题分类
  150. $ttid = (int)$_GET['ttid'];
  151. if ($ttid) {
  152. $add .= " and ttid='$ttid'";
  153. }
  154. $search .= "&sear=1&keyboard=$keyboard&show=$show&showspecial=$showspecial&ttid=$ttid&showisgood=$showisgood&showfirsttitle=$showfirsttitle";
  155. }
  156. //显示重复标题
  157. if ($_GET['showretitle'] == 1) {
  158. $search .= "&showretitle=1&srt=" . intval($_GET['srt']);
  159. $addsrt = "";
  160. $srtid = "";
  161. $first = 1;
  162. $srtsql = $empire->query("select id,title from " . $infotb . " where classid='$classid' group by title having(count(*))>1");
  163. while ($srtr = $empire->fetch($srtsql)) {
  164. if ($first == 1) {
  165. $addsrt .= "title='" . addslashes($srtr['title']) . "'";
  166. $srtid .= $srtr['id'];
  167. $first = 0;
  168. } else {
  169. $addsrt .= " or title='" . addslashes($srtr['title']) . "'";
  170. $srtid .= "," . $srtr['id'];
  171. }
  172. }
  173. if (!empty($addsrt)) {
  174. if ($_GET['srt'] == 1) {
  175. $add .= " and (" . $addsrt . ") and id not in (" . $srtid . ")";
  176. } else {
  177. $add .= " and (" . $addsrt . ")";
  178. }
  179. } else {
  180. printerror("HaveNotReInfo", "ListNews.php?bclassid=$bclassid&classid=$classid" . $addecmscheck . $ecms_hashur['ehref']);
  181. }
  182. }
  183. //只能编辑自己的信息
  184. if ($doselfinfo['doselfinfo']) {
  185. $add .= " and userid='$logininid' and ismember=0";
  186. }
  187. //优化
  188. $yhadd = '';
  189. $yhid = $class_r[$classid][yhid];
  190. $yhvar = 'hlist';
  191. if ($yhid) {
  192. $yhadd = ReturnYhSql($yhid, $yhvar);
  193. }
  194. if (empty($yhadd)) {
  195. //时间范围
  196. $infolday = (int)$_GET['infolday'];
  197. if (empty($infolday)) {
  198. $infolday = $public_r['infolday'];
  199. }
  200. if ($infolday && $infolday != 1) {
  201. $ckinfolday = time() - $infolday;
  202. $yhadd .= "newstime>'$ckinfolday'";
  203. $search .= "&infolday=$infolday";
  204. }
  205. if ($infolday == 1) {
  206. $search .= "&infolday=$infolday";
  207. }
  208. }
  209. //单栏目单表
  210. $singletable = 0;
  211. if ($infomod_r[sonclass] == '|' . $classid . '|') {
  212. $singletablenum = $empire->gettotal("select count(*) as total from {$dbtbpre}enewsclass where tbname='" . $class_r[$classid][tbname] . "' and islast=1");
  213. $singletable = $singletablenum == 1 ? 1 : 0;
  214. }
  215. if ($infomod_r[sonclass] == '|' . $classid . '|' && $singletable == 1) {
  216. if ($yhadd) {
  217. $ewhere = $add ? ' where ' . $yhadd . $add : ' where ' . $yhadd;
  218. } else {
  219. $ewhere = $add ? ' where ' . substr($add, 5) : '';
  220. }
  221. } else {
  222. if ($yhadd) {
  223. $ewhere = " where " . $yhadd . " and classid='$classid'" . $add;
  224. } else {
  225. $ewhere = " where classid='$classid'" . $add;
  226. }
  227. }
  228. //统计
  229. $totalquery = "select count(*) as total from " . $infotb . $ewhere;
  230. $totalnum = (int)$_GET['totalnum'];
  231. if ($totalnum < 1) {
  232. if (empty($ewhere) || $ewhere == " where classid='$classid'") {
  233. $num = $indexchecked == 1 ? $classinfos : $classckinfos;
  234. } else {
  235. $num = $empire->gettotal($totalquery);//取得总条数
  236. }
  237. } else {
  238. $num = $totalnum;
  239. }
  240. //排序
  241. $myorder = RepPostStr($_GET['myorder'], 1);
  242. if ($myorder == 1)//时间
  243. {
  244. $doorder = "newstime desc";
  245. } elseif ($myorder == 2)//评论数
  246. {
  247. $doorder = "plnum desc";
  248. } elseif ($myorder == 3)//人气
  249. {
  250. $doorder = "onclick desc";
  251. } elseif ($myorder == 4)//ID号
  252. {
  253. $doorder = "id desc";
  254. } else//默认排序
  255. {
  256. if (empty($thiscr['listorder'])) {
  257. $doorder = "id desc";
  258. } else {
  259. $doorder = $thiscr['listorder'];
  260. }
  261. }
  262. $search .= "&totalnum=$num";
  263. $search1 = $search;
  264. $search .= "&myorder=$myorder";
  265. $returnpage = page2($num, $line, $page_line, $start, $page, $search);
  266. $phpmyself = urlencode(eReturnSelfPage(1));
  267. //标题分类
  268. $tts = '';
  269. $ttsql = $empire->query("select typeid,tname from {$dbtbpre}enewsinfotype where mid='$modid' order by myorder");
  270. while ($ttr = $empire->fetch($ttsql)) {
  271. $select = '';
  272. if ($ttr[typeid] == $ttid) {
  273. $select = ' selected';
  274. }
  275. $tts .= "<option value='$ttr[typeid]'" . $select . ">$ttr[tname]</option>";
  276. }
  277. $stts = $tts ? "<select name='ttid'><option value='0'>标题分类</option>$tts</select>" : "";
  278. //栏目链接
  279. $getcurlr['classid'] = $classid;
  280. $classurl = sys_ReturnBqClassname($getcurlr, 9);
  281. //导入页面
  282. $deftempfile = ECMS_PATH . 'e/data/html/list/listinfo.php';
  283. if ($infomod_r[listfile]) {
  284. $tempfile = ECMS_PATH . 'e/data/html/list/' . $infomod_r[listfile] . '.php';
  285. if (!file_exists($tempfile)) {
  286. $tempfile = $deftempfile;
  287. }
  288. } else {
  289. $tempfile = $deftempfile;
  290. }
  291. require($tempfile);
  292. db_close();
  293. $empire = null;
  294. ?>