服务器之家:专注于服务器技术及软件下载分享
分类导航

DEDECMS|帝国CMS|Discuz|PHPCMS|Wordpress|ZBLOG|ECSHOP|苹果CMS|极致CMS|CMS系统|

服务器之家 - 建站程序 - PHPCMS - phpcms v9添加热门搜索关键词的方法

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

2019-10-08 11:00phpcms建站网 PHPCMS

目前正在用phpcms v9,需要显示热门搜索关键词,Google了几下没找到完善的解决办法。还是DIY吧。

通过观察可以发现系统是自带了关键词模型的,只是没有实现。 
或许是放在下一个版本里,呵呵~ 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完成!

延伸 · 阅读

精彩推荐
  • PHPCMSphpcms怎么上传歌曲文件

    phpcms怎么上传歌曲文件

    phpcms上传歌曲文件的方法:首先依次打开“设置-站点管理-修改”;然后在附件配置的“允许上传附件类型”中添加自己需要的类型;接着打开“添加模型...

    未知1522023-05-07
  • PHPCMS数据库导入成功,phpcms打不开

    数据库导入成功,phpcms打不开

    问:,数据库导入成功,phpcms打不开 答:您好,查看此域名是解析到 云主机 上的,报错来看应该是您导入的数据库不完整,还差session的表,请您核实 若需...

    未知1822023-05-07
  • PHPCMS如何设置PhpCms广告模块管理 PhpCms广告模块管理图文教程

    如何设置PhpCms广告模块管理 PhpCms广告模块管理图文教程

    PhpCms广告模块管理图文教程,下面给大家总结一下 ...

    PHPCMS教程网3782019-10-14
  • PHPCMSphpcms常见问题解答

    phpcms常见问题解答

    1.为什么phpcms首页幻灯片怎么显示不出来? 答:需要设置文章的 标题图片 如果设置标题图片,则可以在首页以及栏目页以图片方式链接到文章。 2.自定义...

    phpcms教程网2712019-10-07
  • PHPCMSphpcms的栏目缓存无限级罗列展示处理代码(亲测)

    phpcms的栏目缓存无限级罗列展示处理代码(亲测)

    本文为大家详细介绍下phpcms的栏目缓存无限级罗列展示是怎么实现的,粗测试了一下,效果还不错,有需求的朋友可以参考下哈,希望对大家有所帮助 ...

    phpcms教程网8642019-10-11
  • PHPCMSphpcms V9实现QQ登陆OAuth2.0提供下载

    phpcms V9实现QQ登陆OAuth2.0提供下载

    phpcmsV9使用的QQ登陆依然是OAuth1.0,但现在腾讯已经不审核使用OAuth1.0的网站了。这对于使用pc的站长来讲是一个无比巨大的坑。经过对phpcms论坛的一位同学做...

    phpcms教程网3402019-10-11
  • PHPCMSphpcms转移到虚拟空间的详细步骤

    phpcms转移到虚拟空间的详细步骤

    本文向大家介绍phpcms从本地转移到虚拟空间的步骤,转移过程需要改动一部分文件,这里提供如何改动这些文件,以保证你可以顺利转移PHPCMS ...

    phpcms教程网4232019-10-13
  • PHPCMSphpcms v9去除盛大连接 关闭盛大通行证的修改方法

    phpcms v9去除盛大连接 关闭盛大通行证的修改方法

    phpcms v9默认开启了盛大连接,直接使用盛大通告证登录网站,但是盛大通告证的覆盖面有限,比不上QQ或者支付宝,甚至不如人人网、豆瓣之类,于是有朋...

    phpcms教程网5562019-10-13