PHP 自定义错误处理函数
在php开发中我们一般会使用php自带的错误处理方法来处理一些错误,但是有些我们需要自定义一些错误处理机制来解决系统自带不能解决的问题.
基本的错误处理:使用 die() 函数
第一个例子展示了一个打开文本文件的简单脚本,代码如下:
- <?php
- $file=fopen("welcome.txt","r");
- ?>
如果文件不存在,您会获得类似这样的错误:
Warning: fopen(welcome.txt) [function.fopen]: failed to open stream: No such file or directory in C:webfoldertest.php on line 2
为了避免用户获得类似上面的错误消息,我们在访问文件之前检测该文件是否存在,代码如下:
- <?php
- if(!file_exists("welcome.txt"))
- {
- die("File not found");
- }
- else
- {
- $file=fopen("welcome.txt","r");
- }//开源代码phpfensi.com
- ?>
现在,假如文件不存在,您会得到类似这样的错误消息.
File not found比起之前的代码,上面的代码更有效,这是由于它采用了一个简单的错误处理机制在错误之后终止了脚本.
不过,简单地终止脚本并不总是恰当的方式,让我们研究一下用于处理错误的备选的 PHP 函数.
下面我们来看一个自定错误处理函数,代码如下:
- function myErrorHandler($errno, $errstr, $errfile, $errline){
- if(!(error_reporting() &$errno)){return;}
- switch ($errno){
- case E_USER_ERROR:
- echo "<b>My ERROR</b> [$errno] $errstr<br/>";
- echo "错误行:$errline 在文件:$errfile之中<br/>";
- echo " PHP版本: " .PHP_VERSION ." (" .PHP_OS .")<br/>";
- break;
- case E_USER_WARNING:
- echo "<b>My WARNING</b> [$errno] $errstr<br/>";
- break;
- case E_USER_NOTICE:
- echo "<b>My NOTICE</b> [$errno] $errstr<br />";
- break;
- default:
- echo "Unknown error type: [$errno] $errstr<br />";
- break;
- }
- return true;
- }
- function trigger_test($age){//抛出错误的测试函数
- if($age <= 0 || $age > 999) trigger_error("年龄不合法:$age岁", E_USER_ERROR);
- if($age < 18) trigger_error("未成年:$age岁", E_USER_WARNING);
- if($age > 40 && $age < 100) trigger_error("年龄稍大:$age岁", E_USER_NOTICE);
- }
- //如果只是简单统一地处理错误:
- $errorHandler = set_error_handler("myErrorHandler");
- trigger_test(1000);//会抛出一个error级的错误
- function myError($errno, $errstr, $errfile, $errline){
- print_r(func_get_args());
- //具体处理方法
- }
- function myWarning($errno, $errstr, $errfile, $errline){
- print_r(func_get_args());
- //具体处理方法
- }
- function myNtice($errno, $errstr, $errfile, $errline){
- print_r(func_get_args());
- //具体处理方法
- }
如果要分别处理不同错误级别,代码如下:
set_error_handler('myError',E_USER_ERROR);
set_exception_handler('myWarning',E_USER_WARNING);
set_exception_handler('myNtice',E_USER_NOTICE);
trigger_error('故意抛出个错误,还是很严重的哪一种!',E_USER_ERROR);