dedecms织梦文档内容自动关联tag标签加入内链的方法


最终实现效果如下图:内容生成之后会自动加上本篇文章的tags标签(文档生成时候自动加入,编辑器中内容实际没加入,更有利)


1、后台-系统-核心设置-关键字替换,选择【是】

2、后台-系统-其他选项-关键词替换次数,填【1】或者【0】

1:表示文档内容里有多个关键词,只让1个是内链

0:表示文档内容里有多个关键词,都是内链

根据自己的需要填

 



3、打开 /include/arc.archives.class.php 找到,大概在1187行至1241行,整个函数
 

  function ReplaceKeyword($kw,&$body) { ...中间代码省略 }   整个改成  
function ReplaceKeyword($kw,&$body){global $cfg_replace_num;$search = "/(alts*=s*|titles*=s*|srcs*=s*)["|'](.+?)["|']/is";$body = preg_replace_callback($search, array('Archives', '_base64_encode'), $body);$addsql = '';if(isset($this->Fields['tags']) && !empty($this->Fields['aid'])){$this->dsql->SetQuery("SELECT tid FROM `dede_taglist` WHERE aid = '{$this->Fields['aid']}' ");$this->dsql->Execute();$ids = '';while($row = $this->dsql->GetArray()){$ids .= ( $ids=='' ? $row['tid'] : ','.$row['tid'] );}if($ids != ''){$addsql = " WHERE id IN($ids) ";}if($addsql=='') return $body;}$query = "SELECT * FROM `dede_tagindex` $addsql ORDER BY addtime DESC";$this->dsql->SetQuery($query);$this->dsql->Execute();$linkdatas = array();while($row = $this->dsql->GetArray()){$row['keyword'] = $row['tag'];$row['rpurl'] = $cfg_cmsurl."/".urlencode($row['tag'])."/";$linkdatas[] = $row;}if($linkdatas) {$word = $replacement = array();foreach($linkdatas as $v) {$word1[] = '/(?!(<a.*?))' . preg_quote($v['keyword'], '/') . '(?!.*</a>)/s';$word2[] = $v['keyword'];$replacement[] = '<a href="'.$v['rpurl'].'" target="_blank">'.$v['keyword'].'</a>';}if($cfg_replace_num) {$body = preg_replace($word1, $replacement, $body, $cfg_replace_num);} else {$body = str_replace($word2, $replacement, $body);}}$body = preg_replace_callback($search, array('Archives', '_base64_decode'), $body);return $body;}function _base64_encode($matches) {return $matches[1].""".base64_encode($matches[2]).""";}function _base64_decode($matches) {return $matches[1].""".base64_decode($matches[2]).""";}
    4、完成,动态的直接看效果,静态的记得重新生成文档看效果 本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!
本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com