首页 > CMS > PhpCMS > 正文

【phpcms-v9】为phpcms-v9添加热门搜索关键词

2024-09-10 07:15:53
字体:
来源:转载
供稿:网友

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

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

看一下keyword_model.class.php的内容:

  1. defined('IN_PHPCMS'or exit('No permission resources.'); 
  2. pc_base::load_sys_class('model''', 0); 
  3. class keyword_model extends model { 
  4.     public $table_name = ''
  5.     public function __construct() { 
  6.         $this->db_config = pc_base::load_config('database'); 
  7.         $this->db_setting = 'default'
  8.         $this->table_name = 'keyword'
  9.         parent::__construct(); 
  10.     } 

从代码可以看出关键词表名叫 keyword 可是我们查看数据库里没有这样的表名,那就参照相关搜索数据表 tb_search_keyword,我安装的时候用的是tb做表前缀.

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

  1. SET FOREIGN_KEY_CHECKS=0; 
  2.  
  3. -- ---------------------------- 
  4. -- Table structure for `tb_keyword` 
  5. -- ---------------------------- 
  6. DROP TABLE IF EXISTS `tb_keyword`; 
  7. CREATE TABLE `tb_keyword` ( 
  8.   `keyword` char(20) NOT NULL
  9.   `typeid` tinyint(4) NOT NULL default '0'
  10.   `searchnums` int(10) unsigned NOT NULL default '0'
  11.   PRIMARY KEY  (`keyword`),  --Vevb.com 
  12.   UNIQUE KEY `keyword` (`keyword`) 
  13. ) ENGINE=MyISAM DEFAULT CHARSET=gbk; 

这样数据表就建好了,接下来就是添加和调用数据了,打开文件 /phpcms/models/search/index.php.

找到:

  1.  //如果开启相关搜索功能 
  2.             if($setting['relationenble']) { 
  3.  
  4. //在它上面加入以下代码 
  5.  
  6. //加入搜索关键词记录 imbin 2011/9/13 
  7.             if(!emptyempty($result)){ 
  8.                 $this->keyword_log_db = pc_base::load_model('keyword_model'); 
  9.  
  10.                     $res = $this->keyword_log_db->get_one(array('keyword'=>$q,'typeid'=>$typeid)); 
  11.                     if($res) { 
  12.                         //关键词搜索数+1 
  13.                         $this->keyword_log_db->update(array('searchnums'=>'+=1'), array('keyword'=>$q)); 
  14.                     } else { 
  15.                         $this->keyword_log_db->insert(array('keyword'=>$q,'typeid'=>$typeid'searchnums'=>1)); 
  16.                     } 
  17.             } 

这样就实现了搜索关键词的添加,再来看看模板调用的实现,我用的是 get 标签,首先看搜索结果页:/phpcms/templates/default/search/list.html:

  1. {pc:get sql="SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid AND searchnums > 
  2.  5 ORDER BY rand()" num="5" return="keywords"} 
  3.                           {loop $keywords $k=>$v}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}a>{/loop} 
  4. {/pc} 

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

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

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

  1. {pc:get sql="SELECT keyword,typeid FROM tb_keyword ORDER BY searchnums DESC" num="8"  return="keywords"
  2.  {loop $keywords $k=>$v}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}a>{/loop} 
  3.  {/pc} 

OK了,DIY完成.

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表