PHP的错误处理
1,使用die()函数处理简单的错误处理 die()函数的作用:当遇到错误时die() 函数输出一条消息,并退出当前脚本 以一个打开文件为例子:
<?php
$file=fopen("welcome.txt","r");
?>
如果代码中的welcome.txt不存在 就会得到一个类似这样的报错:
Warning: fopen(welcome.txt): failed to open stream: No such file or directory in D:\xampp\php\www\1.php on line 2
当然,在生产过程中(网页提供给用户使用时)我们是不希望出现类似的错误信息的。 这个时间,我们就可以使用die()函数简单的处理一下 具体如下:
<?php
if(!file_exists("welcome.txt"))
{
die("文件不存在");
}
else
{
$file=fopen("welcome.txt","r");
}
?>
当welcomet.txt不存在的时候,就不会再出现和上面一样的的错误提醒了,而是出现我们自己设计的文字:"文件不存在"然后终止程序。
2,自定义错误处理器 错误函数必须有能力处理至少两个参数 (error level 和 error message),但是可以接受最多五个参数(可选的:file, line-number 和 error context) 通过 set_error_handler() 函数设置用户自定义的错误处理程序,然后触发错误(通过 trigger_error()函数触发) 参数error_level值的意思:
1)set_error_handler() 函数基本语法
set_error_handler(errorhandler,E_ALL|E_STRICT);
参数 | 描述 |
---|
errorhandler | 必需。规定用户错误处理函数的名称。 | E_ALLE_STRICT | 必需。规定用户错误处理函数的名称。默认是 “E_ALL”。 |
注释:1,如果使用该函数,会绕过标准 PHP 错误处理程序,同时如果必要,用户定义错误程序通过 die() 终止脚本。 2,如果错误发生在脚本执行之前(比如文件上传时),将不会调用自定义的错误处理程序因为它尚未在那时注册
2)trigger_error()函数基本语法
trigger_error(errormsg,errortype);
参数 | 描述 |
---|
errormsg | 必需。规定错误消息。最大长度 1024 字节。 | errormsg | 可选。规定错误类型。可能的值:E_USER_ERROR E_USER_WARNING E_USER_NOTICE(默认) |
返回值: 如果规定了错误的 errortype,则返回 FALSE。否则返回 TRUE。 3)实例1:
<?php
// 用户定义的错误处理函数
function myErrorHandler($errno, $errstr, $errfile, $errline) {
echo "<b>Custom error:</b> [$errno] $errstr<br>";
echo " Error on line $errline in $errfile<br>";
}
// 设置用户定义的错误处理函数
set_error_handler("myErrorHandler");
$test=2;
// 触发错误
if ($test>1) {
trigger_error("A custom error has been triggered");
}
?>
Custom error: [1024] A custom error has been triggered Error on line 15 in D:\xampp\php\www\1.php 4)实例2:
<?php
// 错误处理函数
function customError($errno, $errstr)
{
echo "<b>Error:</b> [$errno] $errstr<br>";
echo "脚本结束";
die();
}
// 设置错误处理函数
set_error_handler("customError",E_USER_WARNING);
// 触发错误
$test=2;
if ($test>1)
{
trigger_error("变量值必须小于等于 1",E_USER_WARNING);
}
?>
在本例中,如果 “test” 变量大于 “1”,则发生 E_USER_WARNING 错误。如果发生了 E_USER_WARNING,我们将使用我们自定义的错误处理程序并结束脚本,也就是说只有发生E_USER_WARNING 错误才使用我们自定义的错误处理程序,其他的错误还是按照原本设置好的。
3,错误记录 在默认的情况下,根据在 php.ini 中的 error_log 配置,PHP 向服务器的记录系统或文件发送错误记录。通过使用 error_log() 函数,您可以向指定的文件或远程目的地发送错误记录。 1)error_log的定义和用法 error_log() 函数向服务器错误记录、文件或远程目标发送一个错误。 如果成功该函数返回 TRUE,如果失败该函数返回 FALSE。 2)基本语法
error_log(error,type,destination,headers)
3)实例:
<?php
// 错误处理函数
function customError($errno, $errstr)
{
echo "<b>Error:</b> [$errno] $errstr<br>";
echo "已通知网站管理员";
error_log("Error: [$errno] $errstr",1,
"someone@example.com","From: webmaster@example.com");
}
// 设置错误处理函数
set_error_handler("customError",E_USER_WARNING);
// 触发错误
$test=2;
if ($test>1)
{
trigger_error("变量值必须小于等于 1",E_USER_WARNING);
}
?>
结果:
Error: [512] 变量值必须小于等于 1
|