国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

290 lines
12KB

  1. <?php
  2. if (!defined('DEDEINC')) exit('dedebiz');
  3. /**
  4. * 单表模型的文章列表调用标记
  5. *
  6. * @version $Id: arclistsg.lib.php 1 9:29 2010年7月6日Z tianya $
  7. * @package DedeBIZ.Taglib
  8. * @copyright Copyright (c) 2022, DedeBIZ.COM
  9. * @license https://www.dedebiz.com/license
  10. * @link https://www.dedebiz.com
  11. */
  12. /**
  13. * arclistsg解析标签
  14. *
  15. * @access public
  16. * @param object $ctag 解析标签
  17. * @param object $refObj 引用对象
  18. * @return string 成功后返回解析后的标签内容
  19. */
  20. function lib_arclistsg(&$ctag, &$refObj)
  21. {
  22. global $dsql, $PubFields, $cfg_keyword_like, $cfg_index_cache, $_arclistEnv, $envs, $_sys_globals;
  23. //属性处理
  24. $attlist = "typeid|0,row|10,col|1,flag|,titlelen|30,sort|default,keyword|,innertext|,arcid|0,idlist|,channelid|0,limit|,orderway|desc,subday|0";
  25. FillAttsDefault($ctag->CAttribute->Items, $attlist);
  26. extract($ctag->CAttribute->Items, EXTR_SKIP);
  27. $line = $row;
  28. $orderby = strtolower($sort);
  29. if ($col == '') $col = 1;
  30. if (empty($imgwidth)) $imgwidth = "";
  31. if (empty($imgheight)) $imgheight = "";
  32. $innertext = trim($ctag->GetInnerText());
  33. if ($innertext == '') $innertext = GetSysTemplets("part_arclistsg.htm");
  34. if (empty($channelid) && isset($GLOBALS['envs']['channelid'])) {
  35. $channelid = $GLOBALS['envs']['channelid'];
  36. }
  37. if (empty($typeid) && !empty($envs['typeid'])) {
  38. $typeid = $envs['typeid'];
  39. }
  40. if (empty($typeid) && empty($channelid)) {
  41. return "No channel info!";
  42. }
  43. if (!empty($channelid)) $gquery = "SELECT addtable,listfields FROM `#@__channeltype` WHERE id='$channelid' ";
  44. else $gquery = "SELECT ch.addtable,listfields FROM `#@__arctype` tp LEFT JOIN `#@__channeltype` ch ON ch.id=tp.channeltype WHERE id='$typeid'";
  45. $row = $dsql->GetOne($gquery);
  46. $orwheres = array();
  47. $maintable = trim($row['addtable']);
  48. if ($maintable == '') {
  49. return "No addtable info!";
  50. }
  51. //列表调用字段
  52. $listarcs = array('aid', 'typeid');
  53. if (!empty($row['listfields'])) {
  54. $listfields = explode(',', $row['listfields']);
  55. foreach ($listfields as $v) {
  56. if (!in_array($v, $listarcs)) $listarcs[] = $v;
  57. }
  58. }
  59. $arclistquery = join(',', $listarcs);
  60. $arclistquery .= ",arc.aid AS id,arc.senddate AS pubdate";
  61. //按不同情况设定SQL条件 排序方式
  62. if ($idlist == '') {
  63. if ($orderby == 'near' && $cfg_keyword_like == 'N') {
  64. $keyword = '';
  65. }
  66. //时间限制(用于调用最近热门文章、热门评论之类)
  67. if ($subday > 0) {
  68. //这里的时间只能计算到天,否则缓存功能将无效
  69. $ntime = gmmktime(0, 0, 0, gmdate('m'), gmdate('d'), gmdate('Y'));
  70. $limitday = $ntime - ($subday * 24 * 3600);
  71. $orwheres[] = " arc.senddate > $limitday ";
  72. }
  73. if ($flag != '') {
  74. $flags = explode(',', $flag);
  75. for ($i = 0; isset($flags[$i]); $i++) $orwheres[] = " FIND_IN_SET('{$flags[$i]}',flag)>0 ";
  76. }
  77. if (!empty($typeid)) {
  78. //指定了多个栏目时,不再获取子类的id
  79. if (preg_match('#,#', $typeid)) $orwheres[] = " typeid IN ($typeid) ";
  80. else {
  81. //处理交叉栏目
  82. $CrossID = '';
  83. if ((isset($envs['cross']) || $ctag->GetAtt('cross') == '1') && $ctag->GetAtt('nocross') != '1') {
  84. $arr = $dsql->GetOne("SELECT `id`,`topid`,`cross`,`crossid`,`ispart`,`typename` FROM `#@__arctype` WHERE id='$typeid' ");
  85. if ($arr['cross'] == 0 || ($arr['cross'] == 2 && trim($arr['crossid'] == '')))
  86. $orwheres[] = ' typeid IN ('.GetSonIds($typeid).')';
  87. else {
  88. $selquery = '';
  89. if ($arr['cross'] == 1) {
  90. $selquery = "SELECT id,topid FROM `#@__arctype` WHERE typename like '{$arr['typename']}' AND id<>'{$typeid}' AND topid<>'{$typeid}' ";
  91. } else {
  92. $arr['crossid'] = preg_replace('#[^0-9,]#', '', trim($arr['crossid']));
  93. if ($arr['crossid'] != '') $selquery = "SELECT id,topid FROM `#@__arctype` WHERE id IN('{$arr['crossid']}') AND id<>'{$typeid}' AND topid<>'{$typeid}' ";
  94. }
  95. if ($selquery != '') {
  96. $dsql->SetQuery($selquery);
  97. $dsql->Execute();
  98. while ($arr = $dsql->GetArray()) {
  99. $CrossID .= ($CrossID == '' ? $arr['id'] : ','.$arr['id']);
  100. }
  101. }
  102. }
  103. }
  104. if ($CrossID == '') $orwheres[] = ' typeid IN ('.GetSonIds($typeid).')';
  105. else $orwheres[] = ' typeid IN ('.GetSonIds($typeid).','.$CrossID.')';
  106. }
  107. }
  108. //频道ID
  109. if (!empty($channelid)) $orwheres[] = " AND arc.channel = '$channelid' ";
  110. //由于这个条件会导致缓存功能失去意义,因此取消
  111. //if($arcid!=0) $orwheres[] = " arc.id<>'$arcid' ";
  112. }
  113. //文档排序的方式
  114. $ordersql = '';
  115. if ($orderby == 'hot' || $orderby == 'click') $ordersql = " ORDER BY arc.click $orderway";
  116. else if ($orderby == 'id') $ordersql = " ORDER BY arc.aid $orderway";
  117. else if ($orderby == 'near') $ordersql = " ORDER BY ABS(arc.id - ".$arcid.")";
  118. else if ($orderby == 'rand') $ordersql = " ORDER BY rand()";
  119. else $ordersql = " ORDER BY arc.aid $orderway";
  120. //limit条件
  121. $limit = trim(preg_replace('#limit#i', '', $limit));
  122. if ($limit != '') $limitsql = " LIMIT $limit ";
  123. else $limitsql = " LIMIT 0,$line ";
  124. $orwhere = '';
  125. if (isset($orwheres[0])) {
  126. $orwhere = join(' AND ', $orwheres);
  127. $orwhere = preg_replace("#^ AND#i", '', $orwhere);
  128. $orwhere = preg_replace("#AND[ ]{1,}AND#i", 'AND ', $orwhere);
  129. }
  130. if ($orwhere != '') $orwhere = " WHERE $orwhere ";
  131. $query = "SELECT $arclistquery,tp.typedir,tp.typename,tp.isdefault,tp.defaultname,tp.namerule,
  132. tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath
  133. FROM `$maintable` arc LEFT JOIN `#@__arctype` tp ON arc.typeid=tp.id
  134. $orwhere AND arc.arcrank > -1 $ordersql $limitsql";
  135. $md5hash = md5($query);
  136. $needcache = TRUE;
  137. if ($idlist != '') $needcache = FALSE;
  138. else {
  139. $idlist = GetArclistSgCache($md5hash);
  140. if ($idlist != '') $needcache = FALSE;
  141. }
  142. //指定了id或使用缓存中的id
  143. if ($idlist != '' && $_arclistEnv != 'index') {
  144. $query = "SELECT $arclistquery,tp.typedir,tp.typename,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,
  145. tp.moresite,tp.siteurl,tp.sitepath FROM `$maintable` arc LEFT JOIN `#@__arctype` tp ON arc.typeid=tp.id
  146. WHERE arc.aid IN($idlist) $ordersql $limitsql";
  147. }
  148. $dsql->SetQuery($query);
  149. $dsql->Execute("al");
  150. $artlist = "";
  151. $dtp2 = new DedeTagParse();
  152. $dtp2->SetNameSpace("field", "[", "]");
  153. $dtp2->LoadString($innertext);
  154. $GLOBALS['autoindex'] = 0;
  155. $ids = array();
  156. for ($i = 0; $i < $line; $i++) {
  157. for ($j = 0; $j < $col; $j++) {
  158. if ($col > 1) $artlist .= " <div>\r\n";
  159. if ($row = $dsql->GetArray("al")) {
  160. $ids[] = $row['aid'];
  161. $row['filename'] = $row['arcurl'] = GetFileUrl(
  162. $row['id'],
  163. $row['typeid'],
  164. $row['senddate'],
  165. $row['title'],
  166. 1,
  167. 0,
  168. $row['namerule'],
  169. $row['typedir'],
  170. 0,
  171. '',
  172. $row['moresite'],
  173. $row['siteurl'],
  174. $row['sitepath']
  175. );
  176. $row['typeurl'] = GetTypeUrl(
  177. $row['typeid'],
  178. $row['typedir'],
  179. $row['isdefault'],
  180. $row['defaultname'],
  181. $row['ispart'],
  182. $row['namerule2'],
  183. $row['moresite'],
  184. $row['siteurl'],
  185. $row['sitepath']
  186. );
  187. if ($row['litpic'] == '-' || $row['litpic'] == '') {
  188. $row['litpic'] = $GLOBALS['cfg_cmspath'].'/static/defaultpic.gif';
  189. }
  190. if (!preg_match("#^http:\/\/#i", $row['litpic']) && $GLOBALS['cfg_multi_site'] == 'Y') {
  191. $row['litpic'] = $GLOBALS['cfg_mainsite'].$row['litpic'];
  192. }
  193. $row['picname'] = $row['litpic'];
  194. $row['image'] = "<img src='".$row['picname']."' border='0' width='{$imgwidth}' height='{$imgheight}' alt='".preg_replace("#['><]#", "", $row['title'])."' />";
  195. $row['imglink'] = "<a href='".$row['filename']."'>".$row['image']."</a>";
  196. $row['stime'] = GetDateMK($row['pubdate']);
  197. $row['typelink'] = "<a href='".$row['typeurl']."'>".$row['typename']."</a>";
  198. $row['fulltitle'] = $row['title'];
  199. $row['title'] = cn_substr($row['title'], $titlelen);
  200. $row['textlink'] = "<a href='".$row['filename']."'>".$row['title']."</a>";
  201. $row['plusurl'] = $row['phpurl'] = $GLOBALS['cfg_phpurl'];
  202. $row['memberurl'] = $GLOBALS['cfg_memberurl'];
  203. $row['templeturl'] = $GLOBALS['cfg_templeturl'];
  204. if (is_array($dtp2->CTags)) {
  205. foreach ($dtp2->CTags as $k => $ctag) {
  206. if ($ctag->GetName() == 'array') {
  207. //传递整个数组,在runphp模式中有特殊作用
  208. $dtp2->Assign($k, $row);
  209. } else {
  210. if (isset($row[$ctag->GetName()])) $dtp2->Assign($k, $row[$ctag->GetName()]);
  211. else $dtp2->Assign($k, '');
  212. }
  213. }
  214. $GLOBALS['autoindex']++;
  215. }
  216. $artlist .= $dtp2->GetResult()."\r\n";
  217. } //if hasRow
  218. else {
  219. $artlist .= '';
  220. }
  221. if ($col > 1) $artlist .= " </div>\r\n";
  222. } //Loop Col
  223. if ($col > 1) $i += $col - 1;
  224. } //loop line
  225. $dsql->FreeResult("al");
  226. //保存ID缓存
  227. $idsstr = join(',', $ids);
  228. if ($idsstr != '' && $needcache && $cfg_index_cache > 0) {
  229. $mintime = time() - ($cfg_index_cache * 3600);
  230. $inquery = "INSERT INTO `#@__arccache`(`md5hash`,`uptime`,`cachedata`) VALUES ('".$md5hash."', '".time()."', '$idsstr'); ";
  231. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arccache` WHERE md5hash='".$md5hash."' or uptime < $mintime ");
  232. $dsql->ExecuteNoneQuery($inquery);
  233. }
  234. return $artlist;
  235. }
  236. //查询缓存
  237. function GetArclistSgCache($md5hash)
  238. {
  239. global $dsql, $envs, $cfg_makesign_cache, $cfg_index_cache;
  240. //没启用缓存
  241. if ($cfg_index_cache <= 0) return '';
  242. //少量更新禁用缓存
  243. if (isset($envs['makesign']) && $cfg_makesign_cache == 'N') return '';
  244. //正常情况
  245. $mintime = time() - ($cfg_index_cache * 3600);
  246. $arr = $dsql->GetOne("SELECT cachedata,uptime FROM `#@__arccache` WHERE md5hash = '$md5hash' AND uptime > $mintime ");
  247. //没数据
  248. if (!is_array($arr)) return '';
  249. //返回缓存id数据
  250. else return $arr['cachedata'];
  251. }
  252. function lib_GetAutoChannelID2($sortid, $topid)
  253. {
  254. global $dsql;
  255. if (empty($sortid)) $sortid = 1;
  256. $getstart = $sortid - 1;
  257. $row = $dsql->GetOne("SELECT id,typename From #@__arctype WHERE reid='{$topid}' AND ispart<2 AND ishidden<>'1' ORDER BY sortrank asc limit $getstart,1");
  258. if (!is_array($row)) return 0;
  259. else return $row['id'];
  260. }