我的编程空间,编程开发者的网络收藏夹
学习永远不晚

phpcms v9添加热门搜索关键词的方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

phpcms v9添加热门搜索关键词的方法

通过观察可以发现系统是自带了关键词模型的,只是没有实现。

或许是放在下一个版本里,呵呵~ DIY就从 /phpcms/model/keyword_model.class.php入手了。

看一下keyword_model.class.php的内容


复制代码代码如下:

defined('IN_PHPCMS') or exit('No permission resources.');

pc_base::load_sys_class('model', '', 0);

class keyword_model extends model {

public $table_name = '';

public function __construct() {

$this->db_config = pc_base::load_config('database');

$this->db_setting = 'default';

$this->table_name = 'keyword';

parent::__construct();

}

}

从代码可以看出关键词表名叫 keyword 可是我们查看数据库里没有这样的表名。

那就参照相关搜索数据表 tb_search_keyword(我安装的时候用的是tb做表前缀)

新建一个热门搜索关键词数据表 keyword


复制代码代码如下:

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for `tb_keyword`

-- ----------------------------

DROP TABLE IF EXISTS `tb_keyword`;

CREATE TABLE `tb_keyword` (

`keyword` char(20) NOT NULL,

`typeid` tinyint(4) NOT NULL default '0',

`searchnums` int(10) unsigned NOT NULL default '0',

PRIMARY KEY (`keyword`),

UNIQUE KEY `keyword` (`keyword`)

) ENGINE=MyISAM DEFAULT CHARSET=gbk;

这样数据表就建好了,接下来就是添加和调用数据了。

打开文件 /phpcms/models/search/index.php

找到


复制代码代码如下:

//如果开启相关搜索功能

if($setting['relationenble']) {

在它上面加入以下代码


复制代码代码如下:

//加入搜索关键词记录 imbin 2011/9/13

if(!empty($result)){

$this->keyword_log_db = pc_base::load_model('keyword_model');

$res = $this->keyword_log_db->get_one(array('keyword'=>$q,'typeid'=>$typeid));

if($res) {

//关键词搜索数+1

$this->keyword_log_db->update(array('searchnums'=>'+=1'), array('keyword'=>$q));

} else {

$this->keyword_log_db->insert(array('keyword'=>$q,'typeid'=>$typeid, 'searchnums'=>1));

}

}

这样就实现了搜索关键词的添加

再来看看模板调用的实现,我用的是 get 标签。

首先看搜索结果页:/phpcms/templates/default/search/list.html


复制代码代码如下:

{pc:get sql="SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid AND searchnums > 5 ORDER BY rand()" num="5" return="keywords"}

{loop $keywords $k=>$v}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}</a>{/loop}

{/pc}

这里的排序我用了随机,因为我不想每次都出现一样的,呵呵。

附上按搜索次数排序的Sql语句:SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid ORDER BY searchnums DESC

如果是在首页调用,需要去掉$typeid。BTW:如果要在非搜索结果页都要去掉$typeid


复制代码代码如下:

{pc:get sql="SELECT keyword,typeid FROM tb_keyword ORDER BY searchnums DESC" num="8" return="keywords"}

{loop $keywords $k=>$v}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}</a>{/loop}

{/pc}

OK了,DIY完成!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

phpcms v9添加热门搜索关键词的方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

phpcms v9添加热门搜索关键词的方法

通过观察可以发现系统是自带了关键词模型的,只是没有实现。 或许是放在下一个版本里,呵呵~ DIY就从 /phpcms/model/keyword_model.class.php入手了。 看一下keyword_model.class.php的
2022-06-12

批量删除织梦dedecms文档搜索关键词的方法

本文实例讲述了使用SQL命令语句批量删除织梦DEDEcms搜索关键词的方法。分享给大家供大家参考。具体实现方法如下: 一、问题: 这两天准备把织梦清理维护一下,在清理的过程中发现搜索关键词维护这个功能很不好用,300多页面的搜索关键词,不能
2022-06-12

Dedecms搜索时 当然关键词和栏目名相同时 搜索结果为空的问题的解决方法

如果搜索的词和某一个栏目名称相同,如果这个栏目下没有文章,即使别的栏目有这个标题的文章,也搜索不出结果 临时的解决办法: 打开pluhttp://www.cppcns.coms/search.php 删掉或者注释掉: 复制代码代码如下: /
2022-06-12

phpcms v9后台添加文章时选择相关文章可调用其它模型信息的方法

不过这个解决方法修改了一些文件,你可以根据自己的要求酌情使用。。我在这里也详细说一下解决思路,以便后来人参考学习。 phpcmsV9的相关文章http://www.cppcns.com,我们知道只有同模型的文章才可以选择。其他模型的文章是选
2022-06-12

帝国cms给内容页的关键字加上搜索链接的方法

内容页关键字加上链接是现在网站最基本的功能啦,不知道为啥帝国cms官方一直没有加上 不过现在有这样的插件 百度一下可以下载到“帝国cms内容页www.cppcns.com带链接关键字插件”内容关键字加链接