建站软件 优化软件 编程软件 网页辅助 站群程序 网站程序 图像处理 资源教程 字体下载 推荐软件


您的位置:首页 > 建站必知 > phpcms怎么添加热门搜索关键词

phpcms怎么添加热门搜索关键词

时间:2015-07-03 09:04:07  来源:免费模板网 作者:风雪 阅读次数 tagsphpcms

想对自己网站进行二次开发。如别人经常搜索的关键词在搜索框的下面显示。这个怎么实现呢?这个时候就需要对代码进行修改了。请看下文
通过观察可以发现系统是自带了关键词模型的,只是没有实现。 

或许是放在下一个版本里,呵呵~ 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} 

本文地址:https://www.freemoban.com/jzbz/2015/0703/2258.html

猜你喜欢

Copyright:www.freemoban.com 免费模板网 All Rights Reserved 网站备案:辽ICP备19014872号-2   辽公网安备 21010602000376号  辽公网安备:42900402000182号

免责声明:本站部分资源来自互联网收集,版权归原创者所有,如果侵犯了你的权益,我们会及时删除侵权内容,联系QQ:1615187561 谢谢合作!