建站动态:乐数码共分享文章教程6 篇,网站模板0 套,网站源码0份!你还可以: 免费投稿

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

phpcms教程 乐数码    次浏览 0看法
通过观察可以发现系统是自带了关键词模型的,只是没有实现。或许是放在下一个版本里,呵呵~ 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.        }  
  11. }  

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

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

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

  1. //如果开启相关搜索功能  
  2. if($setting['relationenble']) {  

在它上面加入以下代码
 

  1. //加入搜索关键词记录  
  2. if(!emptyempty($result)){  
  3.       $this->keyword_log_db = pc_base::load_model('keyword_model');  
  4.       $res = $this->keyword_log_db->get_one(array('keyword'=>$q,'typeid'=>$typeid));  
  5.        if($res) {  
  6.            //关键词搜索数+1  
  7.            $this->keyword_log_db->update(array('searchnums'=>'+=1'), array('keyword'=>$q));  
  8.        } else {  
  9.            $this->keyword_log_db->insert(array('keyword'=>$q,'typeid'=>$typeid'searchnums'=>1));  
  10.     }  

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

  1. {pc:get sql="SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid AND searchnums > 5 ORDER BY rand()" num="5" 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} 

这里的排序我用了随机,因为我不想每次都出现一样的,呵呵。附上按搜索次数排序的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}  

行了,去试试吧!

转载请注明:乐数码_提供虚拟主机、云主机、域名注册服务,关注网站设计、网页设计、建站教程及建站资源 » phpcms v9 添加热门搜索关键词最新方法