PHP错误处理的三种方式
A、简单的die()语句;
等价于exit();
例:
if(!file_exists('aa.txt')){
die('文件不存在');
} else {
//执行操作
}
//如果上面die()被触发,那么这里echo接不被执行
echo 'ok';
简洁写法:
file_exits('aaa.txt') or die('文件不存在');
echo 'ok';
B、自定义错误和错误触发器
1、错误处理器(自定义错误,一般用于语法错误处理)
创建自定义错误函数(处理器),该函数必须有能力处理至少两个参数(error_level和errormessage),但是可以接受最多五个参数(error_file、error_line、error_context)
语法:
function error_function($error_level,$error_message,$error_file,$error_line,$error_context)
//创建好后还需要改写set_error_handler();函数
set_error_handler('error_function',E_WARNING);//这里error_function对应上面创建的自定义处理器名,第二个参数为使用自定义错误处理器的错误级别;
错误报告级别(了解即可)
这些错误报告级别是错误处理程序旨在处理的错误的不同的类型:
| 值 | 常量 | 描述 |
|---|---|---|
| 2 | E_WARNING | 非致命的 run-time 错误。不暂停脚本执行。 |
| 8 | E_NOTICE |
Run-time 通知。 脚本发现可能有错误发生,但也可能在脚本正常运行时发生。 |
| 256 | E_USER_ERROR | 致命的用户生成的错误。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_ERROR。 |
| 512 | E_USER_WARNING | 非致命的用户生成的警告。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_WARNING。 |
| 1024 | E_USER_NOTICE | 用户生成的通知。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_NOTICE。 |
| 4096 | E_RECOVERABLE_ERROR | 可捕获的致命错误。类似 E_ERROR,但可被用户定义的处理程序捕获。(参见 set_error_handler()) |
| 8191 | E_ALL |
所有错误和警告,除级别 E_STRICT 以外。 (在 PHP 6.0,E_STRICT 是 E_ALL 的一部分) |
例子:
<?php
function error_fun($error_no,$error_info){
echo "错误信息:".$error_info;
}
set_error_handler("error_fun",E_NOTICE);
echo $a;
?>
结果:
错误信息:Undefined variable: a
2、错误触发器(一般用于处理逻辑上的错误)
需求:比如要接收一个年龄,如果数字大于120,就认为是一个错误传统方法:
if($age>120){
echo '年龄错误';exit();
}
使用触发器:
if($age>120){
//trigger_error('错误信息'[,'错误等级']);这里错误等级为可选项,用于定义该错误的级别
//用户定义的级别包含以下三种:E_USER_WARNING 、E_USER_ERROR 、E_USER_NOTICE
trigger_error('年龄错误');//这里是调用的系统默认的错误处理方式,我们也可以用自定义处理器
}
//自定义处理器,与上面相同
function myerror($error_level,$error_message){
echo 'error text';
}
//同时需要改变系统默认的处理函数
set_error_handler('myerror',E_USER_WARNING);//同上面,第一个参数为自定义函数的名称,第二个为错误级别【这里的错误级别通常为以下三种:E_USER_WARNING 、E_USER_ERROR 、E_USER_NOTICE】
//现在再使用trigger_error就可以使用自定义的错误处理函数了
<?php
//自定义的错误函数
function error_fun($error_no,$error_msg){
$error_lev='';
switch ($error_no){
case 256:
$error_lev='E_USER_ERROR';
break;
case 512:
$error_lev='E_USER_WARNING';
break;
case 1024:
$error_lev='E_USER_NOTICE';
break;
case 4096:
$error_lev='E_RECOVERABLE_ERROR';
break;
default:
$error_lev='E_ALL';
break;
}
echo "错误报告级别:$error_lev<br>";
echo "错误 信息:$error_msg";
die();
}
//指定触发错误级别为E_USER_ERROR的函数
set_error_handler('error_fun',E_USER_WARNING);
$time=9;
if ($time>8) {
//调用触发器的同时指定错误级别
trigger_error('您迟到了',E_USER_WARNING);
}
?>
练习题:
1 <?php
2 date_default_timezone_set('PRC');
3 function myerror($error_level,$error_message){
4 $info= "错误号:$error_level
";
5 $info.= "错误信息:$error_message
";
6 $info.= '发生时间:'.date('Y-m-d H:i:s');
7 $filename='aa.txt';
8 if(!$fp=fopen($filename,'a')){
9 '创建文件'.$filename.'失败';
10 }
11 if(is_writeable($filename)){
12 if(!fwrite($fp,$info)){
13 echo '写入文件失败';
14 } else {
15 echo '已成功记录错误信息';
16 }
17 fclose($fp);
18 } else {
19 echo '文件'.$filename.'不可写';
20 }
21 exit();
22 }
23 set_error_handler('myerror',E_WARNING);
24 $fp=fopen('aaa.txt','r');
25 ?>
C、错误日志
默认的根据php.ini中error_log配置,php向服务器的错误记录系统或文件发送错误记录。通过使用error_log()函数可以向文件或远程目的地发送错误记录;
语法:
error_log(error[,type,destination,headers])
type部分一般用3,表示在文件后面追加错误信息,而不会覆盖原内容
destination表示目的地,即存放的文件或远程目的地
如:error_log("$error_info",3,"errors.txt");
