• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

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

    发布者: 火山休眠期 | 发布时间: 2025-7-24 16:17| 查看数: 63| 评论数: 0|帖子模式

    通过观察可以发现系统是自带了关键词模型的,只是没有实现。 
    或许是放在下一个版本里,呵呵~ 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}[url=https://zhuji.jb51.net/index.php?typeid={$v[]{$v['keyword']}[/url]{/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}[url=https://zhuji.jb51.net/index.php?typeid={$v[]{$v['keyword']}[/url]{/loop} 
    {/pc} 

    OK了,DIY完成!

    来源:互联网
    免责声明:如果侵犯了您的权益,请联系站长(1277306191@qq.com),我们会及时删除侵权内容,谢谢合作!

    最新评论

    浏览过的版块

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表