DEDECMS相关文章以关键字怎么修改

DEDECMS相关文章以关键字怎么修改

dedecms相关文章以关键字怎么修改?

DEDE的相关文章完全不相关,有朋友在DEDE官方放出根据TAG显示相关文章,也是很不错,可惜我在根据那边文章改DEDE代码后老是不行,可能是能力有限,当然也有可能是代码有问题

推荐学习:织梦cms

  

现在终于出了解决办法:

1 在 inc_functions.php 最后?>前 加上

代码如下:

//查询指定栏目里包含相应关键字的文章,并列出  //参数说明:$showImg 是否显示缩略图,0表示不显示,1表示显示  // $titleLen 标题长度,0表示无限  // $rowCount 输出行数,0表示无限  // $typeid 栏目ID,0表示所有栏目  // $keyWord 关键字,字符串  function ShowKeyWordArc($showImg,$titleLen,$rowCount,$typeid,$keyWord){  $dsql = new DedeSql(false);  $sql = TypeGetSunID($typeid,$dsql);  <p>//关键字分词技术  $ks = explode(" ",$keyWord);  foreach($ks as $k){  $k = trim($k);  if ($k!="") {  $kwsqlarr[] = " (xkzzz_archives.title like '%$k%')";  //$kwsqlarr[] = " (xkzzz_archives.keywords like '%$k%') "; //如果需要相关到其它文章的关键字,解除此行注释  }  }  $where = implode(' OR ',$kwsqlarr); </p> <p>$sql="Select tp.namerule,tp.typedir,xkzzz_full_search.aid,xkzzz_full_search.url,xkzzz_archives.* From xkzzz_full_search left join xkzzz_archives on xkzzz_full_search.aid=xkzzz_archives.ID left join xkzzz_arctype tp on xkzzz_archives.typeid=tp.ID where {$sql} and ((xkzzz_archives.title like '%".$keyWord."%') or $where) order by xkzzz_full_search.aid desc";  $dsql-&gt;SetQuery($sql);  $dsql-&gt;Execute();  $ss="";  $i=0;  while($row=$dsql-&gt;GetObject()){  $url=GetFileUrl($row-&gt;ID,$row-&gt;typeid,$row-&gt;senddate,$row-&gt;title,$row-&gt;ismake,$row-&gt;arcrank,$row-&gt;namerule,$row-&gt;typedir,$row-&gt;money);  if ($showImg==0){  $ss=$ss."</p>
  • “;  if ($titleLen!=0) $ss=$ss.cn_substr($row->title,$titleLen);  else $ss=$ss.$row->title;  $ss=$ss.”
  • “;  }else{  $ss=$ss.”

  • “;  

    if ($row->litpic!=””) $ss=$ss.”@@##@@litpic.”‘ alt='”.$row->title.”‘ />”;  else $ss=$ss.”@@##@@”;  $ss=$ss.”

    “;  if ($titleLen!=0) $ss=$ss.cn_substr($row->title,$titleLen);  else $ss=$ss.$row->title;  $ss=$ss.”

  • “;  }  $i++;  if (($rowCount!=0)&&($i>=$rowCount)) return $ss;  }  return $ss;  }

    2 放在文章模板页内

    {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}

    就表示是取所有栏目内的相关文章(与当前文章的关键字相关),标题长度最大32,最多显示10条,不显示缩略图

    或 

    {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”高三 语文”)’/}

    可以找到标题里,含有“高三 语文”,或者含有“高三”或“语文”的文章

    例如,这一段:

    相关文章  {dede:likeart titlelen=’24′ row=’10′} [field:textlink/]  {/dede:likeart}

    就改成:

    相关文章  {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}

    申明:这个函数不是我写的根据关键字来相关文章,就用户体验以及SEO来说都是非常好的 

    但是唯一不好的地方就是生成静态的时候会慢很多,哈哈,服务器又要辛苦了

    DEDECMS相关文章以关键字怎么修改DEDECMS相关文章以关键字怎么修改

    © 版权声明
    THE END
    喜欢就支持一下吧
    点赞9 分享