我们首先来看一下DEDE5.7添加自由列表的界面。在图中我们可以看到,正常情况下DEDE官方写了可以用多个关键字:关键字1,关键字2,关键字3……,但是不知道是官方的失误

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

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

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

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

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

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

 

$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的自由列表的多个关键字功能就可以用了!

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

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

到此我们基本上就完美解决了DEDE5.7自由列表中多个关键字无法使用的问题,步骤稍微繁琐了一些,如果大家在使用测试过程中有任何不明白的可以直接联系爱安网技术QQ:520161757

最新资讯
NASA命名约20个新星座,包括“哥斯拉”“绿巨人”

NASA命名约20个新星座

综合报道,美国宇航局命名了约20个新星座,以纪念天体观测
中消协发文喊话苹果:必须保障消费者支付安全

中消协发文喊话苹果:必

中国消费者协会今日在其官网发文喊话苹果公司,要求相关
马云:融资1亿美元都不好意思 风险投资退潮是好事

马云:融资1亿美元都不

马云在2018世界VR产业大会上讲,阿里巴巴创业时融资500
华为明年将在印度生产手机 三年内开设1000家门店

华为明年将在印度生产

全球第二大手机制造商华为将从明年开始在印度生产手机
深圳冻结P2P网贷股权“反转” 一日后即撤下

深圳冻结P2P网贷股权

对于此前多家深圳P2P网贷平台股权冻结一事,10月19日,这
直击|哈啰正式启动打车业务 全国81城接入嘀嗒出租车

直击|哈啰正式启动打

哈啰出行今日宣布正式接入嘀嗒出行,在北京、杭州、武汉
最新文章
dede织梦文章列表隔行换色的方法

dede织梦文章列表隔行

这篇文章主要介绍了dede织梦文章列表隔行换色的方法的
详解DeDeCMS织梦手机版网站首页如何更新

详解DeDeCMS织梦手机

这篇文章主要介绍了详解DeDeCMS织梦手机版网站首页如
Dedecms移动端网站手机网站的搭建的方法

Dedecms移动端网站手

这篇文章主要介绍了Dedecms移动端网站手机网站的搭建
织梦dedecms安装教程 织梦cms怎么使用

织梦dedecms安装教程

在本篇文章中我们给大家分享一下新手如何使用织梦dede
dede把文章批量设为未审核

dede把文章批量设为未

一般情况我们在批量导入文章或者是采集后入库的文章需
dede中调用文章属性的名称(调用自定义属性名称)

dede中调用文章属性的

我们在前面文章给大家讲述了批量添加自定义属性的功能