Zencart 500错误查找和解决方法
有时在一些虚拟主机下(如HostMonster,BlueHost),Zencart网站会莫名奇妙输出空白页面,查看HTTP头,其实可以看到是500错误。
至于500错误的出现原因,一般是由于服务器脚本或是.htaccess有错误。
因为是空白页面没有输出具体的错误位置,所以排查起来很困难。
以下方法是让网站显示了具体的错误位置,错误内容等代码。
application_top.php放入
error_reporting(9);
function onError($errNo, $errMsg, $file, $line, $errcontext) {
$report_title ='错误报告';
$report_msg = "
<strong>错误类型:</strong><blockquote>$errType($errNo)</blockquote>
<strong>错误位置:</strong><blockquote>$file 第 $line 行</blockquote>
<strong>错误信息:</strong><blockquote>$errMsg</blockquote>";
//print_r($errcontext);
echo $report_msg;
echo '<hr>';
}
set_error_handler('onError');
将以上代码添加在
application_top.php 文件的适当位置。
再次打开网站会发xian具体的输出文件位置已经取出。
-------------------------------------------------------------------------------------------
调试PHP错误经常用到的一些
时间:12-05-24 栏目:问题及解决 作者:admin 评论:3 点击: 3,195 次
|
1
2
3
4
|
ini_set('error_log','errorLog.txt');#记录下来所有发现的错误到文件里去。ini_set('display_errors', 1);#嗯,要显示错误ini_set('memory_limit','512M');#有些错误的出现和内存使用有关系,把这个值调大试试看 |
ini_set("error_reporting",E_ALL);
ini_set("error_log","<日志文件名>")
ini_set("log_errors",1);
#所有 ini_set的内容都可以在php.ini中定义
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
|
function _e($msg,$type=''){ static $i=0; $i++; $error['msg'] = $msg; $error['type'] = $type; $GLOBALS[ERROR_STACK_NAME][$i] = $error; return ERROR_STACK_NAME.$i; } /** * 错误处理 */ function onError($errNo, $errMsg, $file, $line, $errcontext) { $errorlevels = array( 2048 => 'Warning', 2048 => 'Notice', 1024 => 'Warning', 1024 => 'Notice', 512 => 'Warning', 256 => 'Error', 128 => 'Warning', 64 => 'Error', 32 => 'Warning', 16 => 'Error', 8 => 'Notice', 4 => 'Error', 2 => 'Warning', 1 => 'Error'); //print_r(array('code'=>$errno, 'string'=>$errstr, 'file'=>$errfile, 'line'=>$errline,'codeinfo'=>$errorlevels[$errno])); $t = error_reporting(); if (!($errNo & error_reporting())) { return; } $errType = $errNo; /** Get Advance Error msg **/ if(strpos($errMsg,ERROR_STACK_NAME)==0){ $i = substr($errMsg,strlen(ERROR_STACK_NAME)); if(isset($GLOBALS[ERROR_STACK_NAME][$i])){ $error = $GLOBALS[ERROR_STACK_NAME][$i]; $errMsg = $error['msg']; $errType = $error['type']; } } $errMsg = nl2br($errMsg); if($errType=='smarty'){ $errType = '模版系统错误'; }elseif ($errType=='sql'){ $errType = '数据库操作错误'; }else{ $errType = "PHP错误[$errType]"; } $title = '系统错误'; $msg = " <strong>错误类型:</strong><blockquote>$errType</blockquote> <strong>错误位置:</strong><blockquote>$file 第 $line 行</blockquote> <strong>错误信息:</strong><blockquote>$errMsg</blockquote> "; echo $msg;flush(); //msgBox($title,$msg,'',false,2); exit(); } function shutdown_function(){ $errorlevels = array( 2048 => 'Warning', 2048 => 'Notice', 1024 => 'Warning', 1024 => 'Notice', 512 => 'Warning', 256 => 'Error', 128 => 'Warning', 64 => 'Error', 32 => 'Warning', 16 => 'Error', 8 => 'Notice', 4 => 'Error', 2 => 'Warning', 1 => 'Error'); $error = error_get_last(); if($error){ echo '</tr></table></div></div></div></iframe><div style="clear:both"></div><div style=" background-color:#FFBB00"><pre>'; echo '最后一个错误:'; $error ['type']= $errorlevels[$error ['type']]; print_r($error ); debug_print_backtrace(); echo '</pre></div>'; }else{ echo '本页面无错误!'; } } register_shutdown_function('shutdown_function');#定义最后一个错误捕获 define('ERROR_STACK_NAME', 'ERROR_STACK'); set_error_handler('onError');#定义错误处理函数 error_reporting(9); |
LH的方法是:
2.从链接入手,通过访问不同模块确定错误可能存在与某个模块
3.从代码入手,链接反复出错,需要查看框架其实处开始
4.从服务器配置入手,切换服务器配置
声明: 本文由(admin)原创编译,转载请保留链接: 调试PHP错误经常用到的一些
Zencart 500错误查找和解决方法的更多相关文章
- 【thinkphp 5 在nginx 环境下路由无法生效(404 500错误 )的解决方法】
非常惭愧的说,由于之前一直使用的是windowservice,安装apache来进行服务器布置的,这种方式也是最简单最直接的方式, 但是由于php的服务大多都是linux栈的,咱们也不能落后呀,在 ...
- 批处理命令篇--配置免安装mysql 5.6.22, 以及1067错误的一个解决方法
mysql 服务启动出现1067错误的一个解决方法: 当服务启动出现1067错误时,可查看“windows 事件查看器”,发现类似错误提示 Can't find messagefile 'F:\ ...
- IIS发布网站浏览之后看到的是文件目录 & Internal Server Error 处理程序“ExtensionlessUrlHandler-ISAPI-4.0_64bit”在其模块列表中有一个错误模块“IsapiModule” 解决方法 & App_global.asax.pduxejp_.dll”--“拒绝访问。 ”
Q:IIS发布网站浏览之后看到的是文件目录 A:它出现了一个说到.NET4.0 更高框架什么的错误,所以我将 .NTE CRL版本由4.0改为2.0了,改为2.0后就出现了只能浏览文件目录了.改为4. ...
- ORA-04091错误原因与解决方法
最近工作中写了一触发器报错:ORA-04091:table XX is mutating, trigger/function may not see it. 下面通过官方文档及网友提供资料分析一下错 ...
- [代码]--IIS发布网站浏览之后看到的是文件目录 & Internal Server Error 处理程序“ExtensionlessUrlHandler-ISAPI-4.0_64bit”在其模块列表中有一个错误模块“IsapiModule” 解决方法 & App_global.asax.pduxejp_.dll”--“拒绝访问。 ”
Q:IIS发布网站浏览之后看到的是文件目录 A:它出现了一个说到.NET4.0 更高框架什么的错误,所以我将 .NTE CRL版本由4.0改为2.0了,改为2.0后就出现了只能浏览文件目录了.改为4. ...
- Hadoop常见错误问题及解决方法总结二
问题导读:1.遇到问题该如何排除错误?2.看不到namenode的可能原因是什么?3.地址占用该如何解决?4.could only be replicatied to 0 nodes, instead ...
- coreseek常见错误原因及解决方法
coreseek常见错误原因及解决方法 Coreseek 中文全文检索引擎 Coreseek 是一款中文全文检索/搜索软件,以GPLv2许可协议开源发布,基于Sphinx研发并独立发布,专攻中文搜索和 ...
- android 真机调试出现错误 INSTALL_FAILED_INSUFFICIENT_STORAGE 的解决方法。
关于这个神奇的 内存不够错误的通常解决方法,网上大把,建议大家在尝试过了网上的方法后再来尝试下我的这种方法. 编译工具: android studio 测试真机:米 2 调试的时候出现:INSTALL ...
- 无法打开物理文件xxx.mdf操作系统错误 5:“5(拒绝访问。)” (Microsoft SQL Server,错误: 5120)的解决方法
无法打开物理文件xxx.mdf操作系统错误 5:“5(拒绝访问.)” (Microsoft SQL Server,错误: 5120)的解决方法 问题描述: 在附加数据库到sql server时,附 ...
随机推荐
- mybatis 总结(1)
注意事项 1.在使用type 和JavaType 以及reusltType ,ofType的时候一定要设置"别名"在mybatis.cfg.xml中设置 <typeAlias ...
- OPENWRT make menuconfig错误之一
1.make menuconfig rm: cannot remove `tmp/.host.mk': Permission denied 退到trunk上级目录sudo chown -R 777 t ...
- 安装lnmp(linux nginx mysql php)
下载或者在云盘里找lnmp1.2-full.tar.gz 用 tar -zxvf lnmp1.2-full.tar.gz解压 进入 ,运行./install.sh安装.根据提示. 如果出现yum锁定, ...
- http response
关键词:http response header 下载文件 案例1: 访问某个链接,然后下载文件,需要特定的http头: header("Content-Type:application/z ...
- SQLServer在多个表中都增加一个字段的方法
1.使用游标 declare @sql varchar(), @name varchar() declare my_cursor scroll cursor for select name from ...
- 使用固件库操作STM32F4时的必要配置(转)
源:使用固件库操作STM32F4时的必要配置 使用STM32F4的固件库时,默认的晶振为25Mhz晶振,因此需要做一定的修改.之前因为一直没有注意这个问题,我捣腾了许久,发现工作时钟总是不对,查阅了一 ...
- 【转】javascript Object使用Array的方法
原文: http://www.cnblogs.com/idche/archive/2012/03/17/2403894.html Array.prototype.push push向数组尾部添加一项并 ...
- Lua基础(一)
1.Lua中有8个基本类型分别为:nil.boolean.number.string.userdata.function.thread和table 2.Lua中的表达式包括数字常量.字符串常量.变量. ...
- springmvc+mybatis下载项目自带模板
1.首先如果要获取javaweb项目中的文件在哪,用到的代码:request.getSession().getServletContext().getRealPath("/WEB-INF/d ...
- linux系统tomcat项目部署和tomcat访问日志
一.只用ip地址访问 先把端口号改成80,然后用 <Host name="localhost" appBase="webapps" 137 ...