首页 > 教程 >
phpcms v9添加热门搜索关键词的方法
2023-02-20教程围观次
简介通过观察可以发现系统是自带了关键词模型的,只是没有实现。或许是放在下一个版本里,呵呵~DIY就从/phpcms/model/keyword_model.class.php入手了。看一下keyword_model.class.php的内容defined(IN_PHPCMS)orexit(Nopermissionresources.);pc_base::load_sys_class(model,,0)
通过观察可以发现系统是自带了关键词模型的,只是没有实现。
或许是放在下一个版本里,呵呵~ DIY就从 /
phpcms/model/keyword_model.class.php入手了。
看一下keyword_model.class.php的内容
defined('IN_PHPCMS') or exit('No permission resources.'); pc_ ::load_sys_class('model', '', 0); class keyword_model extends model { public $table_name = ''; public function __construct() { $this->db_config = pc_ ::load_config('data '); $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_ ::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完成!
下载链接:网站源码/小程序源码/网站模板下载
上一篇:404页面对网站SEO不可忽视
下一篇:提高关键词排名的28个SEO技巧
下载排行
- WordPress主题 JustNews5.2.2 + QAPress问答插件适合源码站虚拟资源站个人博客
- ThinkPHP高仿蓝奏云网盘系统源码/对接易支付系统程序
- 最新JustMedia V2.7.3主题破解版去授权WordPress主题模板
- 最新去水印小程序源码分享/无需后台/对接接口/支持全网去水印功能
- 自带多平台解析接口短视频去水印图集水印小程序源码下载
- TooNaughty网址导航主题/WordPress主题下载
- 最新短视频去水印小程序源码/带流量主/外卖CPS系统/批量解析/修改MD5
- 某鱼最近卖的很火蓝色版微信去水印小程序源码+接口
- 最新版去水印小程序源码/基于WordPress的短视频去水印小程序源码
- 起点导航系统源码最新V2.6开源可运营版