Fatal error: Cannot redeclare 原因与解决方法
今天在用PHP博客程序Wordpress的时候,结果在“后台 - 外观 -小工具”这里,报错如下:
Fatal error: Cannot redeclare hot_comment_viewed() (previously declared in /fujieace/nginxssl/html/wp-content/themes/fujie/inc/function/widget.php:350) in /fujieace/nginxssl/html/wp-content/themes/fujie/inc/function/widget.php on line 350
中文翻译
致命错误:无法重新声明 hot_comment_viewed()(以前在/fujieace/nginxssl/html/wp-content/themes/fujie/inc/function/widget.php:350中声明)
原因:
通过上面的翻译,也能大概猜出来了。
字面意思理解的就是:某个方法被重复定义了。
再通俗点讲就是:你连续两次及以上使用相同名称来定义一个函数。例如:
function myFunction(){}
function myFunction(){}
如果你的程序代码没什么问题,还发生这个错误,在PHP中一般是由于include、require引起来的,具体知识如下:
include:使用include引用外部文件时,只有代码执行到include代码段时,调用的外部文件才会被引用并读取,当引用的文件发生错误时,系统只会给出个警告错误,而整个php文件会继续执行。
require:在php文件被执行之前,php解析器会用被引用的文件的全部内容替换require语句,然后与require语句之外的其他语句组成个新的php文件,最好后按新的php文件执行程序代码。
include和require的区别
使用require语句来调用文件时,如果调用的文件没有找到,require语句会输出错误信息,并且立即终止脚本处理。儿include语句在没有找到文件时则会输出警告,不会终止脚本的处理。
使用require语句调用文件时,只要程序一执行,就会立刻调用外部文件。而通过include语句调用外部文件时,只有程序执行到该代码段时,才会调用外部文件。
include_once:使用include_once会在导入文件前先检测该文件是否在该页面的其他部分被应用过,如果有,则不会重复引用该文件,程序只能引用一次。(要导入的文件中存在一些自定义函数,那么如果在同一个程序中重复导入这个文件,在第二次导入时便会发生错误,因为php不允许相同名称的函数被重复声明)
require_once:require_once语句是require语句的延伸,他的功能与require语句基本一致,不同的是,在应用require_once时,先会检查要引用的文件是不是已将在该程序中的其他地方被引用过,如果有,则不会在重复调用该文件。(同事使用require_once语句在同一页面中引用了两个不同的文件,那么在输出时,只有第一个文件被执行,第二个引用的文件则不会被执行)
include_once和require_once的区别
include_once语句在脚本执行期间调用外部文件发生错误时,但不会影响程序向下运行。而require_once语句则会出现一个致命的错误,用途都是确保一个被包含的文件只能被包含一次,使用这两个语句可以防止意外的多次包含相同的数据库,从而导致函数的重复定义并产生错误。
解决方法
以我这里PHP博客程序Wordpress为例子,由于我是用的Wordpress主题,以前一直是正常的,只是突然出现这个报错了,我解决也很简单,具体如下:
既然说 hot_comment_viewed() 这个函数或方法被重复定义了,那我就直接去到 widget.php 350行,把那个方法屏闭掉或者删除。
349 <?php350 /**************屏闭开始*********************************************351 function hot_comment_viewed($number, $days){352 global $wpdb;353 $sql = "SELECT ID , post_title , comment_count354 FROM $wpdb->posts355 WHERE post_type = 'post' AND post_status = 'publish' AND TO_DAYS(now()) - TO_DAYS(post_date) < $days356 ORDER BY comment_count DESC LIMIT 0 , $number ";357 $posts = $wpdb->get_results($sql);358 $i = 1;359 $output = "";360 foreach ($posts as $post){361 $output .= "\n<li><span class='li-icon li-icon-$i'>$i</span><a href= \"".get_permalink($post->ID)."\" rel =\"bookmark\" title=\" (".$post->comment_count."条评论)\" >".$post->post_title."</a></li>";362 $i++;363 }364 echo $output;365 }366 ***************************屏闭结束*********************************/367 ?>368 <div id="hot_comment_widget">369 <ul>370 <?php // hot_comment_viewed($number, $days); ?>371 <?php wp_reset_query(); ?>372 </ul>373 </div>
注意:
370行的代码也得屏闭掉,因为涉及到调用函数,不屏闭照样会报错误。
最后我才发现,不是主题代码的问题,是由于我最近更新了Wordpress版本的问题,造成了Wordpress版本和主题不兼容,毕竟我的主题是N年以前的老主题了。
现在的Wordpress小工具打开如下图:
还需要提醒大家一点:
虽然说我屏闭代码能够正常进入Wordpress小工具了。
但是,如果你以后不解除屏闭的代码,你网站上但凡是调用此代码的内容是不会再显示出来的。
因此,我为了保证网站的布局不影响,我成功进小工具后修改了相关的设置后,我保存后,我出来又重新把屏闭掉的代码恢复了,这样网站整个都正常了。
最后还要说一下,由于我更新到新版本的Worpdress后,小工具虽然可以进去了,但是发现修改某些设置后并不能保存内容了,也是主题和Wordpress版本不兼容引起的,这个大家要注意一下。
Fatal error: Cannot redeclare 原因与解决方法相关推荐
- 启动pip时,< Fatal error in launcher: Unable to create process using ‘“‘ >问题的原因及解决方法
启动pip时,< Fatal error in launcher: Unable to create process using '"' >问题的原因及解决方法 参考文章: (1 ...
- ERROR 1197 (HY000)问题原因及解决方法
前言 下面介绍的是使用mysql时,1197的问题原因及解决方法.其常见于执行sql语句报错和主从同步报错. 报错如下 ERROR 1197 (HY000) : Multi-statement tra ...
- Keil 提示error C231: ‘INT0‘: redefinition的原因及其解决方法
文章目录 1. 编译现象 2. 分析原因 3. 解决方法 1. 编译现象 2. 分析原因 redefinition 中文意思是 "重复定义".纵览我所写的程序,只有此处首次出现 I ...
- Error【1146】:Table 'xxx.xxx' doesn't exist问题原因及解决方法
前言 我们在使用mysql数据库的时候,有时会因为各种误操作而导致各种问题.下面介绍的导致1146报错的原因及解决方法. 原因 由报错Table 'xxx.xxxxx' doesn't exist可知 ...
- PHP严重致命错误处理:php Fatal error: Cannot redeclare clas
2019独角兽企业重金招聘Python工程师标准>>> 1.错误类型:PHP致命错误 Error type: PHP Fatal error Fatal error: Cannot ...
- Fatal error: Cannot redeclare db_connect() 错误
Fatal error: Cannot redeclare db_connect() (previously declared in D:/wamp/www/flex/new/mysql_inc.ph ...
- windows下 python 使用 pip 安装TA-Lib报错的原因及解决方法
windows下 python 使用 pip 安装TA-Lib报错的原因及解决方法 问题环境 问题描述 问题原因 & 解决办法 问题环境 Windows 10 x64 .python 3.8. ...
- mysql 死锁原因_Mysql并发时经典常见的死锁原因及解决方法
1.mysql都有什么锁 MySQL有三种锁的级别:页级.表级.行级. 表级锁:开销小,加锁快:不会出现死锁:锁定粒度大,发生锁冲突的概率最高,并发度最低. 行级锁:开销大,加锁慢:会出现死锁:锁定粒 ...
- Fail to connect to camera service的几种原因和解决方法
Fail to connect to camera service的几种原因和解决方法 Will.Zhang 10-21 09:42:08.979: I/SurfaceTex ...
最新文章
- 【NLP】NER数据标注中的标签一致性验证
- Asp.Net Core(.net内核)
- 正则表达式格式化字符串
- python3 并行计算_Python-并行计算
- SAP Spartacus storefrontapp不是运行在简单的tomcat服务器上
- 在maven项目中打开jsp_零基础在intellij中打开一个项目复制粘贴内容即可运行的java拼图...
- math.atan_Python中带有示例的math.atan()方法
- pbp 读取 mysql数据_pbp: Django项目开发,个人博客网站类。
- 前端JAVASCRIPT模块化开发
- 【BZOJ4378】[POI2015]Logistyka 树状数组
- android使用FFmpeg解码MP4中的音频并使用AudioTrack播放
- 黑客动画吧-黑客闯关之古墓探秘攻略
- 读取图像数据:通过append方法
- 立创EDA能代替传统的PCB设计软件么?比如AD、protel等?可以
- Un-Routed Net ConStraint报错的原因
- After Effects Guru: Mastering the Timeline After Effects Guru:掌握时间轴 Lynda课程中文字幕
- springboot+websocket构建在线聊天室(群聊+单聊)
- Mac OS 12.3系统版本使用AccessClient堡垒机跳转闪退问题记录
- filemanager-webpack-plugin 打包自动压缩zip
- Epub电子书阅读软件-IOS软件开发团队