给Opencart增加功能:OpenCart分类增加meta title

3,051次阅读
没有评论

共计 4431 个字符,预计需要花费 12 分钟才能阅读完成。

opencart中分类页面meta title默认显示的是分类名称,而没有自定义的meta title,官方给出的解释是meta title在google 已经没有作用的所以省略了。但是我们还是习惯自定义的meta title,下面教大家怎么样添加meta title。

修改后台文件

1、修改admin\controller\catalog\category.php,查找

[php]
$this->data[‘entry_meta_keyword’] = $this->language->get(‘entry_meta_keyword’);
[/php]

在其上添加

[php]
$this->data[‘entry_meta_title’] = $this->language->get(‘entry_meta_title’);
[/php]

2、修改admin\model\catalog\category.php,查找(大约12行)

[php]
foreach ($data[‘category_description’] as $language_id => $value) {
$this->db->query("INSERT INTO " . DB_PREFIX . "category_description SET category_id = ‘" . (int)$category_id . "’, language_id = ‘" . (int)$language_id . "’, name = ‘" . $this->db->escape($value[‘name’]) . "’, meta_keyword = ‘" . $this->db->escape($value[‘meta_keyword’]) . "’, meta_description = ‘" . $this->db->escape($value[‘meta_description’]) . "’, description = ‘" . $this->db->escape($value[‘description’]) . "’");
}
[/php]

修改为

[php]
foreach ($data[‘category_description’] as $language_id => $value) {
$this->db->query("INSERT INTO " . DB_PREFIX . "category_description SET category_id = ‘" . (int)$category_id . "’, language_id = ‘" . (int)$language_id . "’, name = ‘" . $this->db->escape($value[‘name’]) . "’, meta_keyword = ‘" . $this->db->escape($value[‘meta_keyword’]) . "’,meta_title = ‘" . $this->db->escape($value[‘meta_title’]) . "’, meta_description = ‘" . $this->db->escape($value[‘meta_description’]) . "’, description = ‘" . $this->db->escape($value[‘description’]) . "’");
}
[/php]

继续查找(大约46行)

[php]
foreach ($data[‘category_description’] as $language_id => $value) {
$this->db->query("INSERT INTO " . DB_PREFIX . "category_description SET category_id = ‘" . (int)$category_id . "’, language_id = ‘" . (int)$language_id . "’, name = ‘" . $this->db->escape($value[‘name’]) . "’, meta_keyword = ‘" . $this->db->escape($value[‘meta_keyword’]) . "’, meta_description = ‘" . $this->db->escape($value[‘meta_description’]) . "’, description = ‘" . $this->db->escape($value[‘description’]) . "’");
}
[/php]

修改为

[php]
foreach ($data[‘category_description’] as $language_id => $value) {
$this->db->query("INSERT INTO " . DB_PREFIX . "category_description SET category_id = ‘" . (int)$category_id . "’, language_id = ‘" . (int)$language_id . "’, name = ‘" . $this->db->escape($value[‘name’]) . "’, meta_keyword = ‘" . $this->db->escape($value[‘meta_keyword’]) . "’,meta_title = ‘" . $this->db->escape($value[‘meta_title’]) . "’, meta_description = ‘" . $this->db->escape($value[‘meta_description’]) . "’, description = ‘" . $this->db->escape($value[‘description’]) . "’");
}
[/php]

继续查找(大约142行)

[php]
‘meta_keyword’ => $result[‘meta_keyword’],
[/php]

在其上添加

[php]
‘meta_title’ => $result[‘meta_title’],
[/php]

3、修改admin\language\english\catalog\category.php,查找

[php]
$_[‘entry_meta_keyword’] = ‘Meta Tag Keywords:’;
[/php]

在其上添加

[php]
$_[‘entry_meta_title’] = ‘Meta Tag Title:’;
[/php]

4、修改admin\view\template\catalog\category_form.tpl,查找(大约第35行)

[php]
<tr>
<td><?php echo $entry_meta_description; ?></td>
<td><textarea name="category_description[<?php echo $language[‘language_id’]; ?>][meta_description]" cols="40" rows="5"><?php echo isset($category_description[$language[‘language_id’]]) ? $category_description[$language[‘language_id’]][‘meta_description’] : ”; ?></textarea></td>
</tr>
[/php]

在其上添加

[php]
<tr>
<td><?php echo $entry_meta_title; ?></td>
<td><textarea name="category_description[<?php echo $language[‘language_id’]; ?>][meta_title]" cols="40" rows="5"><?php echo isset($category_description[$language[‘language_id’]]) ? $category_description[$language[‘language_id’]][‘meta_title’] : ”; ?></textarea></td>
</tr>
[/php]

修改前台文件

修改catalog\controller\product\category.php,查找(大约第75行)

[php]
$this->document->setTitle($category_info[‘name’]);
[/php]

修改为

[php]
$this->document->setTitle(empty($category_info[‘meta_title’])?$category_info[‘name’]:$category_info[‘meta_title’]);
[/php]

修改数据库

数据库 category_description表中增加meta_title字段,phpmyadmin中运行以下sql语句

[php]
ALTER TABLE `category_description` ADD `meta_title` VARCHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL ;
[/php]

正文完
 0
评论(没有评论)

空瓶子部落

文章搜索
推荐阅读
当你发现你的逻辑很混乱,可用以下方法

当你发现你的逻辑很混乱,可用以下方法

黄金三点论: 介绍了“黄金三点论”的具体应用,即在表达观点时,强迫自己快速说出三个观点。举例说明了如何应用这一...
电腐蚀——汽车电驱的“隐形杀手”!某电驱轴承电腐蚀抑制总成详解(有图)

电腐蚀——汽车电驱的“隐形杀手”!某电驱轴承电腐蚀抑制总成详解(有图)

新能源汽车的电驱系统正日益复杂和高集成化,但在高压高频运行环境下,电机轴承面临一个看似“隐蔽却致命”的威胁——...
试验设计原理及其七个步骤

试验设计原理及其七个步骤

导语:试验设计是一种确定影响过程的因子和过程输出之间关系的动态方法。换句话说,试验设计常被用来寻找因果关系。为...
SPC控制图的八种模式分析

SPC控制图的八种模式分析

SPC控制图有八种模式,即八种判断异常的检验准则,每一种检验准则代表一种异常现象,应用SPC控制图进行过程评估...
养生‖维生素自测指南,建议收藏

养生‖维生素自测指南,建议收藏

♥维生素和矿物质对我们的健康非常重要 ♥当体内缺乏某种营养素时,身体会通过一些特定的症状来提示 ♥日常均衡饮食...
最新文章
群晖 Let’s Encrypt 泛域名证书自动更新

群晖 Let’s Encrypt 泛域名证书自动更新

目前acme协议版本更新,开始支持泛域名(wildcard),也就是说,可以申请一个类似*.domain.co...
可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

还在为找优秀片源难、广告多、平台会员太贵而烦恼?今天给大家挖到一款真正的影视宝藏工具——小猫影视! 作为开源免...
【收藏】一次性解决TV点播/直播自由

【收藏】一次性解决TV点播/直播自由

很多时候,资源就在面前,但是我们视而不见,因为长久的安逸,已经让人失去动手的兴趣。但是每次我需要挨个切换APP...
OpenWrt 存储空间扩容的两种方案

OpenWrt 存储空间扩容的两种方案

说明:当我们通过群晖 VMM 虚拟机安装 Open­Wrt 时,默认会分配一个 10GB 的存储空间,而实际情...
OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt是什么?OpenWrt一般常见于无线路由器(软路由)第三方固件,它是一个高效、可靠、功能多的路由...
热门文章
提高过程能力指数(CP/CPK)的途径

提高过程能力指数(CP/CPK)的途径

编者按:过程能力指数(CP/CPK)想必各位质量人都耳熟能详、运用自如,质量工程师之家前期也共享过数篇关于过程...
SPC控制图的八种模式分析

SPC控制图的八种模式分析

SPC控制图有八种模式,即八种判断异常的检验准则,每一种检验准则代表一种异常现象,应用SPC控制图进行过程评估...
测量高手放大招:圆跳动测量技巧总结

测量高手放大招:圆跳动测量技巧总结

01. 前言 在五金机加工厂实际的测量工作中,经常碰到要求测量两个要素的圆跳动问题, 利用不同的测量辅件及夹具...
过程能力分析(CP&cpk)

过程能力分析(CP&cpk)

引入过程能力分析的目的? 在我们现有的管理过程中,我们经常会遇到有些具体指标总是不尽人意,存在许多需要改进的地...
新能源汽车 “两会”精神宣贯会

新能源汽车 “两会”精神宣贯会

此次和大家分享新能源汽车相关政策: [embeddoc url=”https://www.ctro...
最新评论
多乐士 多乐士 通过摸索发现ssh拉取会报错,直接网页访问下载会报404错误,不知道原因;但是可以通过群晖CM注册表访问下载,其方法如下: Container Manager-注册表-设置-新增-注册表名称随便写,注册表URL填你的加速地址,勾选信任的SSL自我签署证书,登录信息不填-应用-使用你的地址,这是注册表会显示了,在搜索栏中输入映像名称,搜索结果在每一页的最后一个,你需要划到最后一个进行下载,实测可正常下载安装。 以上供网友参考。
多乐士 多乐士 还有一个比较简单的方法,只是需要一些外部工具。 1、讲损毁硬盘取出,装入外部移动硬盘 2、打开Diskgenius,定位到硬盘 3、格式化系统分区 4、重新插入硬盘 5、存储池->修复存储池即可
多乐士 多乐士 写的不错的文章
辞了老衲 辞了老衲 这个确实有帮助。
渋驀 渋驀 当然任何时候都可以用curl命令和crontab来实现动态更新DDNS的ip地址: 1、安装crontab之后为root用户创建文件/var/spool/cron/root 2、创建并配置ddnsupdate.sh,放到/usr/bin/文件下,文件内容(以he.net为例): Autodetect my IPv4/IPv6 address: IPV4:curl -4 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" IPV6:curl -6 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" 3、添加执行权限chomod +x /usr/bin/ddnsupdate.sh 4、编辑root用户的crontab:*/10 * * * * /usr/binddnsupdate.sh,每10分钟执行一次。好了,可以享受你的DDNS了
21410 21410 请问下载链接在那里?
madkylin madkylin 不错,不错,谢谢分享了,好东西啊 :lol:
feilung feilung 求方法
zengsuyi zengsuyi 应该挺不错的
zise zise 看看是怎么操作的。。 :oops: