国内流行的内容管理系统(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.

317 lines
13KB

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