注册 | 登录 |
地方论坛门户及新闻和人才网址大全

织梦关键词自动内链、php5.5以上失效问题解决方法

时间:2021-07-21人气:-


后台-系统-核心设置-关键字替换 【是】后台-系统-其他选项-关键词替换次数 【1】或者【0】

关键词长短优先级问题

比如有“长词”、“我是大长词”、“我是小长词”,同时在一篇文章中出现,程序会优先使用短的词。

织梦关键词自动内链、php5.5以上失效问题解决方法-85模板网

织梦关键词自动内链、php5.5以上失效问题解决方法-85模板网

长短优先级问题和PHP5.5以上问题的解决方法

打开 /include/arc.archives.class.php 找到

$query = "SELECT * FROM keywords WHERE rpurl<>'' ORDER BY rank DESC";

改成

$query = "SELECT char_length(keyword) AS num,aid,keyword,rpurl,rank FROM keywords WHERE rpurl<>'' ORDER BY num DESC";

继续找到

"#".preg_quote($word)."#"

改成

"#".preg_quote($word, "#")."(?!<)#"

继续找到

$body = @preg_replace_callback("#(^|>)([^<]+)(?=<|$)#sU", "_highlight('\2', $karr, $kaarr, '\1')", $body);

改成

global $cfg_replace_num;if($cfg_replace_num > 0){$query = "SELECT char_length(keyword) AS num,aid,keyword,rpurl,rank FROM keywords WHERE rpurl<>'' ORDER BY num DESC";$this->dsql->SetQuery($query);$this->dsql->Execute();while($row = $this->dsql->GetArray()){$key = trim($row['keyword']);$key_url=trim($row['rpurl']);$body = str_replace_limit($key, "<a href='$key_url' target='_blank'><u>$key</u></a>", $body, $cfg_replace_num);}}else{$query = "SELECT char_length(keyword) AS num,aid,keyword,rpurl,rank FROM keywords WHERE rpurl<>'' ORDER BY num DESC";$this->dsql->SetQuery($query);$this->dsql->Execute();while($row = $this->dsql->GetArray()){$key = trim($row['keyword']);$key_url=trim($row['rpurl']);$body = str_replace($key, "<a href='$key_url' target='_blank'><u>$key</u></a>", $body);}}

继续找到

//高亮专用

在它上面加入

//指定替换次数功能function str_replace_limit($search, $replace, $subject, $limit){if(is_array($search)){foreach($search as $k=>$v){$search[$k] = "#".preg_quote($search[$k], "#")."(?!<)#";}}else{$search = "#".preg_quote($search, "#")."(?!<)#";}return preg_replace($search, $replace, $subject, $limit);}

完成,最终效果

织梦关键词自动内链、php5.5以上失效问题解决方法-85模板网


上篇:dedecms SQL注入漏洞

下篇:织梦判断是否有子栏目,有就输出 javascript:; ,...