找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 136|回复: 0

[cms教程] dedecms关键词维护里面字数多的词优先字数少的词的解决办法

[复制链接]

该用户从未签到

发表于 2020-11-8 12:26:32 | 显示全部楼层 |阅读模式

您需要 登录 才可以下载或查看,没有账号?立即注册

×
织梦后台的关键词维护默认的情况是字数少的词优先于字数多的词,比如我们有两个这样的词:创业、创业方向,第二个词包含了第一个词,在文章中如果出现“创业方向”这个词,默认情况下只会给创业两个字添加关键词超链接,而不是整个词,那么我们怎么样才能实现字数多的词优先于字数少的词呢?下面就告诉大家具体的解决方法:
         
        我们找到并打开/include/arc.archives.class.php文件,在里面找到如下代码:
         
        function ReplaceKeyword($kw,&$body)
            {
                global $cfg_cmspath;
                $maxkey = 5;
                $kws = explode(",",trim($kw));    //以分好为间隔符
                $i=0;
                $karr = $kaarr = $GLOBALS['replaced', = array();
         
                //暂时屏蔽超链接
                $body = preg_replace("#()(.*)()#isU", '\\1-,-\\4-[-\\6', $body);
         
                /*
                foreach($kws as $k)
                {
                    $k = trim($k);
                    if($k!="")
                    {
                        if($i > $maxkey)
                        {
                            break;
                        }
                        $myrow = $this->dsql->GetOne("SELECT * FROM #【分隔符】@__keywords WHERE keyword='$k' AND rpurl'' ");
                        if(is_array($myrow))
                        {
                            $karr[, = $k;
                            $GLOBALS['replaced',[$k, = 0;
                            $kaarr[, = "[url={$myrow[,$k[/url]";
                        }
                        $i++;
                    }
                }
                */
                $query = "SELECT * FROM #【分隔符】@__keywords WHERE rpurl'' ORDER BY rank 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[, = "$key";
                }
         
                // 这里可能会有错误
                $body = @preg_replace("#(^|>)([^
         
                //恢复超链接
                $body = preg_replace("#()#isU", '\\1>\\3
                return $body;
            }
         
        注意查找代码的时候先手动去掉代码里面的【分隔符】字样!
         
        找到后将其替换为如下代码:
         
            function ReplaceKeyword($kw,&$body)
            {
            global $cfg_cmspath,$dsql;
            $maxkey = 5;
            $kws = explode(",",trim($kw)); //以分好为间隔符
            $i=0;
            $karr = $kaarr = $GLOBALS['replaced', = array();
            //暂时屏蔽超链接
            $body = preg_replace("/()(.*)()/isU", '\\1-,-\\4-[-\\6', $body);
            $query="SELECT * FROM #【分隔符】@__keywords WHERE rpurl'' and sta=1 ORDER BY length(keyword)desc";
            $dsql->SetQuery($query);
            $dsql->Execute();
            while($row = $dsql->GetArray())
            {
            $key = trim($row['keyword',);
            $key_url=trim($row['rpurl',);
            $karr[, = $key;
            $kaarr[, = "$key";
            }
            foreach ($karr as $key => $word)
            {
            $body = preg_replace("/(^|>)([^
         
         
        '\\1')", $body);
            //echo $body."
";
            //恢复超链接
            $body = preg_replace("/()/isU", '\\1>\\3
            $body = preg_replace("/()(.*)()/isU", '\\1-,-\\4-[-\\6', $body);
            }
            //恢复超链接
            $body = preg_replace("/()/isU", '\\1>\\3
         
         
            return $body;
            }
            }
            //End Archives
            //高亮专用, 替换多次是可能不能达到最多次
            function _highlight($string, $words, $result, $pre)
            {
            global $cfg_replace_num;
            $string = str_replace('\"', '"', $string);
        if($GLOBALS['replaced',[$words, == 1){
            return $pre.$string;
            }
        if($cfg_replace_num > 0){
            $string = preg_replace("/".preg_quote($words)."/", $result, $string, $cfg_replace_num);
            if(strpos($string, $words) !== false)
            {
                $GLOBALS['replaced',[$words, = 1;
                }
                }
        else{$string = str_replace($words, $result, $string);
        }
        return $pre.$string;
        }
         
        注意手动去掉代码里面的【分隔符】字样!
         
        替换完成后保存即可,然后生成一下文章内容试试。
回复

使用道具 举报

网站地图|页面地图|文字地图|Archiver|手机版|小黑屋|找资源 |网站地图

GMT+8, 2024-10-8 14:48

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表