扯远了,说明天的重点“关键字内链”,其实DEDE之前考虑过这个问题的,但是有一些BUG。 DEDE后台里面 核心->批量维护->文档关键字维护 其实这个当时设计出来的时候就是用来做内链的。
但是你总发觉得它不怎么好用,总会出这样哪样的问题。但是我们只需要修改一部分代码就可以让DEDE自动替换关键字了,并且只是文档中只要出现了的都完全替换。
打开 /include/arc.archives.class.php 文件,在修改最后的两个方法,按下面的方法进行修改。 主要修改了ReplaceKeyword里面查询关键字的时候排序的算法,然后注释了一个判断
/** * 高亮问题修正, 排除alt title <a></a>直接的字符替换 * * @param string $kw * @param string $body * @return string */ function ReplaceKeyword($kw,&$body) { global $cfg_cmspath; $maxkey = 5; $kws = explode(",",trim($kw)); //以分好为间隔符 $i=0; $karr = $kaarr = $GLOBALS['replaced'] = array(); //暂时屏蔽超链接 $body = preg_replace("#(<a(.*))(>)(.*)(<)(/a>)#isU", '\1-]-\4-[-\6', $body); /* foreach($kws as $k) { $k = trim($k); if($k!="") { if($i > $maxkey) { break; } $myrow = $this->dsql->GetOne("SELECT * FROM idea_keywords WHERE keyword='$k' AND rpurl<>'' "); if(is_array($myrow)) { $karr[] = $k; $GLOBALS['replaced'][$k] = 0; $kaarr[] = "<a href='{$myrow['rpurl']}'><u>$k</u></a>"; } $i++; } } */ $query = "SELECT * FROM idea_keywords WHERE rpurl<>'' ORDER BY keyword DESC"; $this->dsql->SetQuery($query); $this->dsql->Execute(); while($row = $this->dsql->GetArray()) { $key = trim($row['keyword']); $key_url=trim($row['rpurl']); $karr[] = $key; $kaarr[] = "<a href='$key_url' target='_blank'><u>$key</u></a>"; } // 这里可能会有错误 $body = @preg_replace("#(^|>)([^<]+)(?=<|$)#sUe", "_highlight('\2', $karr, $kaarr, '\1')", $body); //恢复超链接 $body = preg_replace("#(<a(.*))-]-(.*)-[-(/a>)#isU", '\1>\3<\4', $body); return $body; }}//End Archives//高亮专用, 替换多次是可能不能达到最多次function _highlight($string, $words, $result, $pre){ global $cfg_replace_num; $string = str_replace('"', '"', $string); // if($cfg_replace_num > 0) // { // foreach ($words as $key => $word) // { // if($GLOBALS['replaced'][$word] == 1) // { // continue; // } // $string = preg_replace("#".preg_quote($word)."#", $result[$key], $string, $cfg_replace_num); // if(strpos($string, $word) !== FALSE) // { // $GLOBALS['replaced'][$word] = 1; // } // } // } // else // { $string = str_replace($words, $result, $string); // } return $pre.$string;}本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!