五金机电设备 發表於 2023-5-23 00:00:00

如何给phpcms v9增加类似于phpcms 2008中的关键词表

<p>
最近用phpcms v9二次开发一个人站点,之前用2008中有个比较舒服的关键词全部显示出来功能,而v9将关键词列表功能增加到了搜索中,如果搜索一个关键词就会自动产生一个增加到了search_keyword表中,这一点不是很喜欢v9;站内搜索功能,我觉得一般会用得比较少,而我们在增加文章的时候实际上就把关键词分隔开了,为什么还要多此一举了,其实改起来也比较简单<br><br>
在model文件夹中增加一个keyword_ext_model.class.php。keyword_model实际是存在model文件夹中的,不知道为什么没有keyword这张表?<br><br><strong>所以还是不要在这个基本上增加,也许将来这个model会用上</strong></p>
<p>
<span><u>复制代码</u></span> 代码如下:</p>
<p>
<br>
&lt;?php<br>
defined('IN_PHPCMS') or exit('No permission resources.');<br>
pc_base::load_sys_class('model', '', 0);<br>
class keyword_ext_model extends model {<br>
    public $table_name = '';<br>
    public function __construct() {<br>
        $this-&gt;db_config = pc_base::load_config('database');<br>
        $this-&gt;db_setting = 'default';<br>
        $this-&gt;table_name = 'keyword_ext';<br>
        parent::__construct();<br>
    }<br>
}<br>
?&gt;</p>
<p>
<br><strong>然后创建一张表</strong></p>
<p>
<span><u>复制代码</u></span> 代码如下:</p>
<p>
<br>
CREATE TABLE `t_v9_keyword_ext` (<br>
  `tagid` smallint(5) unsigned NOT NULL AUTO_INCREMENT,<br>
  `tag` char(50) NOT NULL,<br>
  `style` char(5) NOT NULL,<br>
  `usetimes` smallint(5) unsigned NOT NULL DEFAULT '0',<br>
  `lastusetime` int(10) unsigned NOT NULL DEFAULT '0',<br>
  `hits` mediumint(8) unsigned NOT NULL DEFAULT '0',<br>
  `lasthittime` int(10) unsigned NOT NULL DEFAULT '0',<br>
  `listorder` tinyint(3) unsigned NOT NULL DEFAULT '0',<br>
  `modelid` smallint(6) DEFAULT '0',<br>
  PRIMARY KEY (`tagid`),<br>
  UNIQUE KEY `tag` (`tag`),<br>
  KEY `usetimes` (`usetimes`,`listorder`),<br>
  KEY `hits` (`hits`,`listorder`)<br>
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;</p>
<p>
<br><strong>最后一步在phpcms/modules/content/fields/keyword 中增加一个 input.inc.php</strong></p>
<p>
<span><u>复制代码</u></span> 代码如下:</p>
<p>
<br>
function tags($field, $value)<br>
    {<br>
        if(!$value) return '';<br>
        if(strpos($value, ','))<br>
        {<br>
            $s = ',';<br>
        }<br>
        else<br>
        {<br>
            $s = ',';<br>
        }<br><br>
        $keywords = isset($s) ? array_unique(array_filter(explode($s, $value))) : array($value);<br>
        $keyword_db = pc_base::load_model('keyword_ext_model');<br><br>
        foreach($keywords as $tag)<br>
        {<br>
            $tag = trim($tag);<br>
            $keyword_db-&gt;delete(array("tag"=&gt;$tag,"modelid"=&gt;$this-&gt;modelid));<br>
            $c=$this-&gt;db-&gt;count("keywords like '%".$tag."%'");<br>
            $keyword_db-&gt;insert(array("modelid"=&gt;$this-&gt;modelid,"tag"=&gt;$tag,"usetimes"=&gt;$c,"lastusetime"=&gt;SYS_TIME),false,true);<br>
        }<br><br>
        return implode($s, $keywords);<br>
}</p>
<p>
<br>
这样在文章增加关键词的时候,会自动增加到keyword_ext中一份,调用全站tags的时候直接调上这个表就行了。<font>请得先清除全站缓存,否则修改后看不到效果。</font></p>
頁: [1]
查看完整版本: 如何给phpcms v9增加类似于phpcms 2008中的关键词表