dede5.7自由列表不能获取多个关键字如何解决

这篇文章主要介绍了dede5.7自由列表不能获取多个关键字如何解决,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。

10多年的平舆网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。全网营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整平舆建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“平舆网站设计”,“平舆网站推广”以来,每个客户项目都认真落实执行。

dede5.7自由列表不能获取多个关键字?

我们首先来看一下DEDE5.7添加自由列表的界面。

dede5.7自由列表不能获取多个关键字如何解决

在图中我们可以看到,正常情况下DEDE官方写了可以用多个关键字:关键字1,关键字2,关键字3……,但是不知道是官方的失误还是其他的原因,添加多个关键字以后,并没有任何的效果,反而检索不到任何内容了,我们根据大家反映的问题,给大家整理了彻底解决这个问题的方法。

涉及到的文件:替换include\arc.freelist.class.php

dede5.7自由列表不能获取多个关键字如何解决

我们能够看到,牵扯到的代码如上图所示。

我们先把两个代码进行隐藏!

我们再自己写一个相关语句:

$orwhere .=  "AND (".$this->GetKeywordSql($keyword)." )";

最后,我们再下方找到位置后添加自己写的相关搜索条件和规则

function GetKeywordSql($keyword)
    {
        $ks = explode(',',$keyword);
        $kwsql = '';
        $kwsqls = array();
        foreach($ks as $k)
        {
            $k = trim($k);
            if(strlen($k)<1)
            {
                continue;
            }
            if(ord($k[0])>0x80 && strlen($k)<2)
            {
                continue;
            }
            $k = addslashes($k);
            $kwsqls[] = " arc.title LIKE '%$k%' ";
        }
        if(!isset($kwsqls[0]))
        {
            return '';
        }
        else
        {
            $kwsql = join(' OR ',$kwsqls);
            return $kwsql;
        }
    }
    /**
     *  获得关键字SQL,统计记录使用
     *
     * @access    private
     * @return    string
     */
    function GetRowSql($keyword)
    {
        $ks = explode(',',$keyword);
        $kwsql = '';
        $kwsqls = array();
        foreach($ks as $k)
        {
            $k = trim($k);
            if(strlen($k)<1)
            {
                continue;
            }
            if(ord($k[0])>0x80 && strlen($k)<2)
            {
                continue;
            }
            $k = addslashes($k);
            $kwsqls[] = " title LIKE '%$k%' ";
        }
        if(!isset($kwsqls[0]))
        {
            return '';
        }
        else
        {
            $kwsql = join(' OR ',$kwsqls);
            return $kwsql;
        }

把上面的代码加入到页面下下方,现在DEDE的自由列表的多个关键字功能就可以用了!

到此还没有结束!小编在实际测试过程中遇到了一个问题,我们添加了两个关键字,那是为了让进一步过滤,还是为了增加更广泛的关键字呢?这个问题困扰了我很久,通过以上的代码,我测试出了相关的解决方案:

dede5.7自由列表不能获取多个关键字如何解决

我们可以看到,在这个地方,如果我们用的是“OR”那么就表示或者,也就是我们说的扩大了检索的范围,让只要出现的关键字文章都会出现,如果我们换成“AND”,就代表缩小检索的范围,表示文章中既有关键字1,也必须有关键字2。

感谢你能够认真阅读完这篇文章,希望小编分享dede5.7自由列表不能获取多个关键字如何解决内容对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,遇到问题就找创新互联,详细的解决方法等着你来学习!


当前名称:dede5.7自由列表不能获取多个关键字如何解决
分享URL:http://azwzsj.com/article/ihpooc.html