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

所属分类: CMS教程 / phpcms 阅读数: 1797
收藏 0 赞 0 分享
通过观察可以发现系统是自带了关键词模型的,只是没有实现。
或许是放在下一个版本里,呵呵~ 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完成!
更多精彩内容其他人还在看

PHPCMS系统自带标签说明

关键字描述:说明 标签 系统 channelid 首页 专题 推荐 图片 文章 PHPCMS系统自带标签说明 首页最新文章列表 articlelist(0,1,0,1,0,0,10,46,0,0,0,1,2,0,0,0,1,1) 首页热点下载列表 downlist
收藏 0 赞 0 分享

phpcms语法规则

关键字描述:规则 语法   < if > loop name 字母 --> /loop 1、变量表示 {$name}被解析成<?=$name?>,表示显示变量$name的值,其中的“name&rdquo
收藏 0 赞 0 分享

phpcms将下载地址替换为图片显示

关键字描述:图片 显示 地址 下载
收藏 0 赞 0 分享

如何把PHPCMS的网站和数据库删除

关键字描述:删除 数据库 网站 如何 PHPCMS mysql 程序 修改 如果 如何把PHPCMS的网站和数据库删除 如果网站换空间了,原来的空间还保存着PHPCMS的mysql数据库,那我们怎么把他删除呢? 很简单 1.删除mysql数据库:通过PHPMYADMIN
收藏 0 赞 0 分享

phpcms关于标签和频道的基础概念

关键字描述:基础 概念 频道 标签 关于   调用 一个 文章 我们 phpcms一直是很多站长使用的建站系统,我们今天谈一下phpcms标签和频道的一些基础知识。 1、 何谓标签? phpcms 一直以来采用的是标签调用的方法,这样就能
收藏 0 赞 0 分享

PHPCMS网站转移空间教程

关键字描述:教程 空间 转移 网站 文件 目录 数据库   PHPCMS 有关phpcms网站转移空间,备份数据库转移空间的文章不是很多,所以就发表操作方法: 1.备份mysql数据库 现在的空间基本都有phpmyadmin 首先进入phpmyadm
收藏 0 赞 0 分享

phpcms常见问题解答

关键字描述:常见 频道 目录 建立 设置 ftp 标签   文章 可以 1.为什么phpcms首页幻灯片怎么显示不出来? 答:需要设置文章的 标题图片 如果设置标题图片,则可以在首页以及栏目页以图片方式链接到文章。 2.自定义phpcms的标签
收藏 0 赞 0 分享

phpcms如何使用水印功能

关键字描述:功能 使用 如何 水印 图片 字体 文字 需要 文件 中文 phpcms水印功能只有在添加标题图片的时候生成带水印的图片。 编辑器上传的图片不能增加水印和缩略图 添加水印功能: 1,首先查看服务器参数查看 图形处理 GD Library 这个选项是不
收藏 0 赞 0 分享

PHPCMS 模板安装导入教程

关键字描述:教程 导入 安装 模板 目录 更新 管理 依次 然后 方案 关于phpcms模板安装教程,导入模板的方法: 1.模板安装 下载已发布共享的模板文件包,解压后上传模板目录至templates目录下,进入后台模板风格 -〉方案管理(见下图),启
收藏 0 赞 0 分享

phpcms模仿QQ和MSN消息提示的效果

关键字描述:提示 效果 消息 模仿 " popTop if else & screen.width-2 你一定很喜欢像QQ或者MSN好友登录提示的效果吧,那么怎么样能在网页中实现呢?正好我在蓝色理想中发现了这段代码,贴出给大家看看(注意,如果使用以下代码,先
收藏 0 赞 0 分享
查看更多