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

所属分类: CMS教程 / dedecms 阅读数: 1416
收藏 0 赞 0 分享

我们首先来看一下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

更多精彩内容其他人还在看

Dedecms自定义模型解决会员无法投稿的方法

这篇文章主要为大家介绍了Dedecms自定义模型解决会员无法投稿的方法,通过新建文章模型与栏目实现会员投稿功能,是dedecms二次开发中非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

DedeCMS新建模型字段中【附件样式】的修改方法

这篇文章主要为大家介绍了DedeCMS新建模型字段中【附件样式】的修改方法,是dedecms二次开发中针对字段操作的典型应用,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms的sql标签中传入参数的方法

这篇文章主要为大家介绍了dedecms的sql标签中传入参数的方法,是进行dedecms数据库程序开发中非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

织梦dede后台卡、假死解决方法

用过织梦的网友,特别是dede栏目或是数据非常多的情况下,我们从后台第一次登录的话,不少网友都会发现登录完一般都会出现dede后台卡,或是dede后台卡死,或是非常卡的情况
收藏 0 赞 0 分享

DEDECMS内容页分页过多、过长问题最佳解决方案

最近由于我们网站添加了图片栏目,小编一个图片就分一页这样的话,我们的内容页面的分页就很多,10几个分页一页显示比较难看,所以想到了用这个方法,感觉网友的分享
收藏 0 赞 0 分享

dedecms调用当前栏目的子栏目的两种方法分享

dedecms大家想必不会陌生,算是国内使用较为广泛的一款文章类CMS系统了,使用过程中也许我们需要用到调用当前栏目的子栏目,那么应该如何操作呢,下面我们来分享2种方法
收藏 0 赞 0 分享

dedecms实现列表页缩略图随机调用的方法

这篇文章主要为大家介绍了dedecms实现列表页缩略图随机调用的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms搬家时出现数据库导入失败的解决方法

这篇文章主要为大家介绍了dedecms搬家时出现数据库导入失败的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms实现将表单订单发送到邮箱实例代码

这篇文章主要为大家介绍了dedecms实现将表单订单发送到邮箱的实现方法,需要的朋友可以参考下
收藏 0 赞 0 分享

DedeCMS实现MySQL修复表的方法

DedeCMS用户碰到数据表出现报错“dede_search_keywords' is marked as crashed and should be repaired”的情况下,就需要对MySQL数据表进行修复。这篇文章主要为大家介绍了DedeCMS实现MySQL修复表的方法,
收藏 0 赞 0 分享
查看更多