All articles| All Pictures| All Softwares| All Video| Go home page| Write articles| Upload pictures

Reading number is top 10 articles
PHP程序加速探索之代码优化_[PHP教程]
轻松掌握Ajax.net系列教程一:部署AJAX.NET_[Asp.Net教程]
关于C#中timer类,在C#里关于定时器类就有3个_[Asp.Net教程]
PHP伪静态隐藏传递参数名的几种方法_[PHP教程]
技巧实例:ASP.NET生成静态页面实现方法_.net资料_编程技术
C#中正则表达式进行忽略大小写的字符串替换_[Asp.Net教程]
用XML和XSL来生成动态页面_[XML教程]
C#中的@符号的使用及注意事项_[Asp.Net教程]
比较测试PHP+MYSQL分页机制两种方案_php资料_编程技术
delphi类型文件声明方式
Reading number is top 10 pictures
LiXiang early youth photo
哥斯达黎加的门将是如何练成的
Magnificent cloud2
Average female college students2
南昌铁路局攸县车站125户铁路职工微利房终成骗局
Compared GDP and per capita income in China for 40 years
Sell the barbecue as says father du breul3
世界五大海盗
A man's favorite things3--ZhouWeiTong
奇趣的世界记录1
Download software ranking
Dance with duck(male prostitution)
Tram sex maniac 2 (H) rar bag5
The cock of the Grosvenor LTD handsome
天龙八部最新服务端
电车之狼R
尖东毒玫瑰A
asp.netWeb服务器高级编程
I'm come from Beijing1
WebService在.NET中的实战应用教学视频 → 第4集
C++编程教程第三版
归海一刀 published in(发表于) 2014/2/17 7:42:30 Edit(编辑)
利用PHP自定义错误处理器处理出错信息_[PHP教程]

利用PHP自定义错误处理器处理出错信息_[PHP教程]

利用PHP自定义错误处理器处理出错信息_[PHP教程]

如果您是PHP老手,当然知道当PHP脚本出错时发生了什么事情。此时PHP解析器将在屏幕上给出错误信息,如 Fatal error: Call to undefined function on line 19 --,因此程序在此处终止。这个信息会吓到客户,他可能立即打电话和你进行咨询。


幸运的是,这里有解决办法。PHP拥有内置工具,可以让开发人员捕捉脚本错误然后将它们转到自定义的错误处理器。此时则可以对处理器进行编程显示更多关于错误的详细信息。还可以将错误写入文件或数据库以采取补救措施。有时候还可以对处理器编写程序忽略错误消息。


本文中,我将阐述如何使用PHP的错误处理API构建用户自定义的错误处理器,并且说明如何以简单而友好的方式显示和管理脚本的错误信息。


错误类型和报告级别


我们从最基本的开始。PHP有三种最基本的错误类型,从低级到高级分别为:注意、警告和错误(或致命错误)。通常情况下,注意和警告不会终止程序;但是致命错误则是危险故障(例如,调用一个没有定义的函数或参考一个不存在的对象),将导致程序中断。这些错误有可能在启动、解析、编译或运行时发生。


关键字如E_NOTICE, E_ERROR等用于表明错误的不同类型和等级。在PHP手册上可以获得它们的详细信息列表。


脚本阶段错误显示由error_reporting()函数进行控制。这一函数针对不同的错误等级设置不同的参数。表A给出了使用此函数报告警告和致命错误的脚本程序。


表A


// display warnings and errors
error_reporting(E_WARNING | E_ERROR);
// this will generate a notice, which will never be displayed
echo undefinedVar;
// this will generate a fatal error, which will be displayed
callUndefFunc();
?>


将表B中的代码与上面的进行比较发现,Listing B中隐藏错误信息甚至隐藏致命信息,使得错误信息不会被显示出来。


表B


// turn off error display
// no errors will be displayed
error_reporting(0);
// this will generate a notice
echo undefinedVar;
// this will generate a fatal error
callUndefFunc();
?>


表C中的代码将所有错误信息甚至简单的注意事项都显示出来:


表C


// all errors will be displayed
error_reporting(E_ALL);
// this will generate a notice
echo undefinedVar;
// this will generate a fatal error
callUndefFunc();
?>


如以上3个例子所示,error_reporting()函数在控制错误发生时,在屏幕上显示内容非常重要。这里的关键字是displayed,其表达的意思是错误不被显示而不是错误没有发生。因此,发生致命错误时(例如不正确的函数调用),程序将被终止;但是,此时没有任何消息显示给用户。


下面的例子(表 D)说明了这种情况:


表D


// no errors will be displayed
error_reporting(0);
// start a task
echo "Starting task...";
// call an undefined function
// a fatal error occurs during task processing
callMe();
// end the task
echo "Successfully completed task...";
?>


在表D中,在调用echo()函数时发生了致命错误,程序执行时到这点被终止,但是却没有任何错误消息给出,用户不知道这种情况还以为程序在正确运行。下面的结论是非常明显的:不给出错误报告非常危险,因为不论过程是否完成它常导致不正确的结论。


注意:调用不带任何参数的error_reporting()将返回当前的错误报告等级。
自定义错误处理器


很明显,隐藏错误报告是不正确的,你肯定想知道有什么其他办法加以改进。自定义错误处理器就是一个很好的能取代PHP默认错误处理系统的解决方法。自定义错误处理器可以以任何方式设置处理错误信息,包括信息如何显示。


PHP函数中,完成这一功能的是set_error_handler()函数。错误发生时,此函数被自动调用,然后给出4个参数:错误代码、错误消息、发生错误的脚本名称和错误出现的行,此函数对错误管理负责。


表E给出一个简单例子:


表E


// define custom handler
set_error_handler('myHandler');
// custom handler code
function myHandler(code, msg, file, line) {
echo "Just so you know, something went wrong at line line of your script file. The system says that the error code was code, and the reason for the error was: msg. Sorry about this!";
}
// generate a notice
echo undefVar;
?>


当运行此脚本的时候,会出现下面的信息:


Just so you know, something went wrong at line 11 of your /dev/error1.php. The system says that the error code was 8, and the reason for the error was: Undefined variable: undefVar. Sorry about this!


此时,PHP的默认错误处理器被用户定义的myHandler()函数所取代,undefVar变量被激活,PHP通知未定义变量的信息,此信息在运行时引擎产生,然后传递给myHandler()函数,同时错误发生的地址也传递给此函数。然后myHandler()函数输出友好信息解释错误。


注意:错误和致命错误很重要,它们会绕过自定义错误处理器,然后以PHP默认的错误处理机制进行显示。显示这些信息可使用前面讨论的标准error_reporting()函数进行控制。


例1:动态错误页面和e-mail警报


表F给出了另一个范例,当发生错误时,将动态产生HTML错误页面,并且通过e-mail向Web管理员进行报告。


表F


// define custom handler
set_error_handler('myHandler');
// custom handler code
function myHandler(code, msg, file, line, context) {
// print error page
echo "";
echo "

Error!

";
echo "";
echo "An error occurred while processing your request. Please visit our home page and try again.";
echo "
";
echo "";
// email error to admin
body = "msg at file (line), timed at " . date ("d-M-Y h:i:s", mktime());
body .= "\n\n" . print_r(context, TRUE);
mail ("webmaster@domain.dom", "Web site error", body);
// halt execution of script
die();
}
// generate a notice
echo undefVar;
?>


这里,自定义的错误处理器在遇到错误时动态产生HTML错误页面。此错误信息也能被e-mail信息捕获,然后通过PHP内置的mail()函数发送给管理员。


这里出现了myHandler()函数的一个新参数context。这是myHandler()函数的第五个参数,是可选项。它包含了当前变量状态的快照。包括对管理员有用的上下文信息,有利于减少调试时间。


例2:自定义错误日志


表G给出了另一个例子,这个例子说明自定义错误处理器如何将详细的错误信息输入到文件。


表G


// define custom handler
set_error_handler('myHandler');
// custom handler code
function myHandler(code, msg, file, line) {
// print error page
echo "";
echo "

Error!

";
echo "";
echo "An error occurred while processing your request. Please visit our home page and try again.";
echo "
";
echo "";
// log error to file, with context
logData = date("d-M-Y h:i:s", mktime()) . ", code, msg, line, file\n";
file_put_contents("web.log", logData, FILE_APPEND);
// halt execution of script
die();
}
// generate a warning
echo is_float();
?>


与前面的例子相似,它也产生一个错误页面并且将错误数据输入到文件,以利于管理员进行查看。数据以CSV格式进行存储,并且有简单的数据分析和报告。请注意在本例和前面实例中,错误处理代码结束时调用die()函数,以确保脚本不再运行。


如上面的范例所示,自定义错误处理器允许以友好的方式处理PHP脚本错误。并且可以发挥自己的创造性,不过需要记住的是:任何灵活性的增加都伴随着开销和时间的增加。







添加到del.icio.us 添加到新浪ViVi 添加到百度搜藏 添加到POCO网摘 添加到天天网摘365Key 添加到和讯网摘 添加到天极网摘 添加到黑米书签 添加到QQ书签 添加到雅虎收藏 添加到奇客发现 diigo it 添加到饭否 添加到飞豆订阅 添加到抓虾收藏 添加到鲜果订阅 digg it 貼到funP 添加到有道阅读 Live Favorites 添加到Newsvine 打印本页 用Email发送本页 在Facebook上分享


Disclaimer Privacy Policy About us Site Map

If you have any requirements, please contact webmaster。(如果有什么要求,请联系站长)
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.