php自动内链处理速度慢,织梦关键词自动内链、关键词长短优先级问题、php5.5以上失效问题解决方法...

关键词内链开启步骤后台-系统-核心设置-关键字替换  【是】后台-系统-其他选项-关键词替换次数  【1】

关键词长短优先级问题

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

解决关键词长短优先级问题的方法

打开 /include/arc.archives.class.php 找到$query = "SELECT * FROM dede_keywords WHERE rpurl<>'' ORDER BY rank DESC";

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

继续找到"#".preg_quote($word)."#"

改成"#(?)(?!

完成

最终效果

PHP版本高于5.5无法使用关键词內链的解决方法

打开 /include/arc.archives.class.php 找到$body = @preg_replace_callback("#(^|>)([^

改成global $cfg_replace_num;if($cfg_replace_num > 0){$query = "SELECT char_length(keyword) AS num,aid,keyword,rpurl,rank FROM dede_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, "$key", $body, $cfg_replace_num);}}else{$query = "SELECT char_length(keyword) AS num,aid,keyword,rpurl,rank FROM dede_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, "$key", $body);}}

继续找到//高亮专用

在它上面加入//指定替换次数功能function str_replace_limit($search, $replace, $subject, $limit){if(is_array($search)){foreach($search as $k=>$v){$search[$k] = '#(?)(?!)(?!

完成

标签:

本文地址:织梦关键词自动内链、关键词长短优先级问题、php5.5以上失效问题解决方法 https://www.shenqiu123.com/a/jianzhan/rumen/7401.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值