PHP 错误与异常 笔记与总结(8)自定义错误处理函数 set_error_handler()

通过 Set_error_handler() 函数设置用户自定义的错误处理函数。

步骤:

① 创建错误处理函数

② 设置不同级别调用函数

Set_error_handler() 函数制定接管错误处理—— 如果使用了该函数,程序会绕过标准的 PHP 错误处理。

摘自:php.net

mixed set_error_handler ( callable $error_handler [, int $error_types = E_ALL | E_STRICT ] )
设置一个用户的函数(error_handler)来处理脚本中出现的错误。

本函数可以用你自己定义的方式来处理运行中的错误, 例如,在应用程序中严重错误发生时,或者在特定条件下触发了一个错误(使用 trigger_error()),你需要对数据/文件做清理回收。

重要的是要记住 error_types 里指定的错误类型都会绕过 PHP 标准错误处理程序, 除非回调函数返回了 FALSE。 error_reporting() 设置将不会起到作用而你的错误处理函数继续会被调用 —— 不过你仍然可以获取 error_reporting 的当前值,并做适当处理。 需要特别注意的是带 @ error-control operator 前缀的语句发生错误时,这个值会是 0。

同时注意,在需要时你有责任使用 die()。 如果错误处理程序返回了,脚本将会继续执行发生错误的后一行。

以下级别的错误不能由用户定义的函数来处理: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT。
error_handler
用户的函数需要接受两个参数:错误码和描述错误的 string。 另外有可能提供三个可选参数:发生错误的文件名、发生错误的行号 以及发生错误的上下文(一个指向错误发生时活动符号表的 array)。 该函数可以表示为:

handler ( int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] )
errno
第一个参数 errno,包含了错误的级别,是一个 integer。
errstr
第二个参数 errstr,包含了错误的信息,是一个 string。
errfile
第三个参数是可选的,errfile, 包含了发生错误的文件名,是一个 string。
errline
第四个参数是一个可选项, errline, 包含了错误发生的行号,是一个 integer。
errcontext
第五个可选参数, errcontext, 是一个指向错误发生时活动符号表的 array。 也就是说,errcontext 会包含错误触发处作用域内所有变量的数组。 用户的错误处理程序不应该修改错误上下文(context)。
如果函数返回 FALSE,标准错误处理处理程序将会继续调用。

error_types
就像error_reporting 的 ini 设置能够控制错误的显示一样, 此参数能够用于屏蔽 error_handler 的触发。 如果没有该掩码, 无论 error_reporting 是如何设置的, error_handler 都会在每个错误发生时被调用。

返回值

如果之前有定义过错误处理程序,则返回该程序名称的 string;如果是内置的错误处理程序,则返回 NULL。 如果你指定了一个无效的回调函数,同样会返回 NULL。 如果之前的错误处理程序是一个类的方法,此函数会返回一个带类和方法名的索引数组(indexed array)。

【例1】

a.使用 PHP 内置错误处理函数(使用自定义错误处理函数被注释掉了)

<?php
header(‘content-type:text/html;charset=utf-8‘);
//显示所有错误
error_reporting(-1);

//自定义错误处理程序
//参数1:$errno 错误级别
//参数2:$errmsg 错误信息
//参数3:$file 错误文件
//参数4:$line 错误行号
function customerError($errno, $errmsg, $file, $line){
    echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
    echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
    echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
    die;
}

//使用自定义错误处理程序接管内置的 PHP 错误处理程序
//set_error_handler(‘customerError‘);

//测试
echo $test;

输出:

( ! ) Notice: Undefined variable: test in D:\practise\php\Error\error1.php on line 22

b.使用自定义错误处理函数:

<?php
header(‘content-type:text/html;charset=utf-8‘);
//显示所有错误
error_reporting(-1);

//自定义错误处理程序
//参数1:$errno 错误级别
//参数2:$errmsg 错误信息
//参数3:$file 错误文件
//参数4:$line 错误行号
function customerError($errno, $errmsg, $file, $line){
    echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
    echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
    echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
    die;
}

//使用自定义错误处理程序接管内置的 PHP 错误处理程序
set_error_handler(‘customerError‘);

//测试
echo $test;

输出:

错误代码: [8] Undefined variable: test
错误行号: D:\practise\php\Error\error1.php文件中的第22行
PHP 版本: 5.3.10(WINNT)

c. 测试 警告 与 致命错误:

<?php
header(‘content-type:text/html;charset=utf-8‘);
//显示所有错误
error_reporting(-1);

//自定义错误处理程序
//参数1:$errno 错误级别
//参数2:$errmsg 错误信息
//参数3:$file 错误文件
//参数4:$line 错误行号
function customerError($errno, $errmsg, $file, $line){
    echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
    echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
    echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
    //die;
}

//使用自定义错误处理程序接管内置的 PHP 错误处理程序
set_error_handler(‘customerError‘);

//测试
//Notice
echo $test;
echo ‘<hr/>‘;

//Warning
settype($var, ‘dee‘);
echo ‘<hr/>‘;

//Fatal Error:依然使用内置的 PHP 错误处理函数
echo dee();

输出:

错误代码: [8] Undefined variable: test
错误行号: D:\practise\php\Error\error1.php文件中的第22行
PHP 版本: 5.3.10(WINNT)
---------------------------------------------------------------------
错误代码: [2] settype() [function.settype]: Invalid type
错误行号: D:\practise\php\Error\error1.php文件中的第24行
PHP 版本: 5.3.10(WINNT)
---------------------------------------------------------------------
( ! ) Fatal error: Call to undefined function dee() in D:\practise\php\Error\error1.php on line 26

d. 测试手动抛出错误

<?php
header(‘content-type:text/html;charset=utf-8‘);
//显示所有错误
error_reporting(-1);

//自定义错误处理程序
//参数1:$errno 错误级别
//参数2:$errmsg 错误信息
//参数3:$file 错误文件
//参数4:$line 错误行号
function customerError($errno, $errmsg, $file, $line){
    echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
    echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
    echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
    //die;
}

//使用自定义错误处理程序接管内置的 PHP 错误处理程序
set_error_handler(‘customerError‘);

//测试
//Notice
echo $test;
echo ‘<hr/>‘;

//Warning
settype($var, ‘dee‘);
echo ‘<hr/>‘;

//Fatal Error:依然使用内置的 PHP 错误处理函数
//echo dee();

//手动抛出错误
trigger_error(‘a test of error‘,  E_USER_ERROR);

输出:

错误代码: [8] Undefined variable: test
错误行号: D:\practise\php\Error\error1.php文件中的第23行
PHP 版本: 5.3.10(WINNT)

---------------------------------------------------------
错误代码: [2] settype() [function.settype]: Invalid type
错误行号: D:\practise\php\Error\error1.php文件中的第27行
PHP 版本: 5.3.10(WINNT)

---------------------------------------------------------
错误代码: [256] a test of error
错误行号: D:\practise\php\Error\error1.php文件中的第34行
PHP 版本: 5.3.10(WINNT)

注:如果不使用用户自定错误,而使用 PHP 内置的错误处理程序,当遇到 E_USER_ERROR 级别的错误时,会报致命错误 Fatal Error,并且程序终止向下执行。

e.在同一脚本中如果不想使用自定义错误处理函数时,可以使用 restore_error_handler() 函数取消自定义错误处理函数的接管。

<?php
header(‘content-type:text/html;charset=utf-8‘);
//显示所有错误
error_reporting(-1);

//自定义错误处理程序
//参数1:$errno 错误级别
//参数2:$errmsg 错误信息
//参数3:$file 错误文件
//参数4:$line 错误行号
function customerError($errno, $errmsg, $file, $line){
    echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
    echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
    echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
    //die;
}

//使用自定义错误处理程序接管内置的 PHP 错误处理程序
set_error_handler(‘customerError‘);

//测试
//Notice
echo $test;
echo ‘<hr/>‘;

//Warning
settype($var, ‘dee‘);
echo ‘<hr/>‘;

//Fatal Error:依然使用内置的 PHP 错误处理函数
//echo dee();

//手动抛出错误,并且程序终止执行
trigger_error(‘a test of error‘, E_USER_ERROR);

//取消使用自定义错误处理函数
restore_error_handler();
echo $dee;

输出:

错误代码: [8] Undefined variable: test
错误行号: D:\practise\php\Error\error1.php文件中的第23行
PHP 版本: 5.3.10(WINNT)

----------------------------------------------------------
错误代码: [2] settype() [function.settype]: Invalid type
错误行号: D:\practise\php\Error\error1.php文件中的第27行
PHP 版本: 5.3.10(WINNT)

----------------------------------------------------------
错误代码: [256] a test of error
错误行号: D:\practise\php\Error\error1.php文件中的第34行
PHP 版本: 5.3.10(WINNT)

( ! ) Notice: Undefined variable: dee in D:\practise\php\Error\error1.php on line 38

f. 继续使用自定义处理函数接管错误处理,并设置set_error_handler() 函数的第二个参数:设置哪些错误交给自定义错误函数处理:

<?php
header(‘content-type:text/html;charset=utf-8‘);
//显示所有错误
error_reporting(-1);

//自定义错误处理程序
//参数1:$errno 错误级别
//参数2:$errmsg 错误信息
//参数3:$file 错误文件
//参数4:$line 错误行号
function customerError($errno, $errmsg, $file, $line){
    echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
    echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
    echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
    //die;
}

//使用自定义错误处理程序接管内置的 PHP 错误处理程序
set_error_handler(‘customerError‘);

//测试
//Notice
echo $test;
echo ‘<hr/>‘;

//Warning
settype($var, ‘dee‘);
echo ‘<hr/>‘;

//Fatal Error:依然使用内置的 PHP 错误处理函数
//echo dee();

//手动抛出错误,并且程序终止执行
trigger_error(‘a test of error‘, E_USER_ERROR);

//取消使用自定义错误处理函数
restore_error_handler();
echo $dee;
echo ‘<hr>‘;

//继续使用自定义错误处理函数,并且设置除了 Notice 级别的错误外的错误,交给自定义错误处理函数处理
set_error_handler(‘customerError‘, E_ALL&~E_NOTICE);
echo $dee;

echo ‘continue‘;

输出:

错误代码: [8] Undefined variable: test
错误行号: D:\practise\php\Error\error1.php文件中的第23行
PHP 版本: 5.3.10(WINNT)

---------------------------------------------------------------
错误代码: [2] settype() [function.settype]: Invalid type
错误行号: D:\practise\php\Error\error1.php文件中的第27行
PHP 版本: 5.3.10(WINNT)

--------------------------------------------------------------
错误代码: [256] a test of error
错误行号: D:\practise\php\Error\error1.php文件中的第34行
PHP 版本: 5.3.10(WINNT)

( ! ) Notice: Undefined variable: dee in D:\practise\php\Error\error1.php on line 38

--------------------------------------------------------------
( ! ) Notice: Undefined variable: dee in D:\practise\php\Error\error1.php on line 43

注:

换行符

unix系列用 \n

windows系列用 \r\n

mac用 \r

PHP中可以用PHP_EOL来替代,以提高代码的源代码级可移植性

参考:http://www.cnblogs.com/codefor/archive/2011/06/18/2084300.html
时间: 2024-07-30 16:59:51

PHP 错误与异常 笔记与总结(8)自定义错误处理函数 set_error_handler()的相关文章

PHP 错误与异常 笔记与总结(11 )register_shutdown_function() 函数的使用

通过 register_shutdown_function 方法,可以让我们设置一个当执行关闭时可以被调用的另一个函数. 也就是说,当我们的脚本执行完成或者意外死掉导致 php 执行即将关闭时,我们的这个函数会被调用. [使用场景] ① 页面被(用户)强制停止 ② 程序代码意外终止或超时 ③ php4 中没有析构函数,可以使用该函数模拟析构函数 shutdown.php <?php header("content-type:text/html;charset=utf-8"); c

PHP 错误与异常 笔记与总结(10)错误处理器测试

关联文件:myErrorHandler.php (上一篇) 先测试通知级别的错误的自定义处理: testErrorHandler.php <?php require_once 'myErrorHandler.php'; error_reporting(-1); set_error_handler(array('myErrorHandler', 'deal')); //通知级别错误 echo $notice; 运行,在 D:\practise\php\From\notice 生成 noticeLo

服务器上出现应用程序错误。此应用程序的当前自定义错误设置禁止

原文:服务器上出现应用程序错误.此应用程序的当前自定义错误设置禁止 误设置禁止远程查看应用程序错误的详细信息(出于安全原因). 之前自己也碰到過這種情況.特此整理,希望能夠幫助有困惑的挨踢人士~ 说明: 服务器上出现应用程序错误.此应用程序的当前自定义错误设置禁止查看应用程序错误的详细信息. 详细信息: 若要使他人能够从本地服务器计算机上查看此特定错误信息的详细信息,请在位于当前 Web 应用程序根目录下的“web.config”配置文件中创建一个 <customErrors> 标记.然后应将

PHP 错误与异常 笔记与总结(17 )像处理异常一样处理 PHP 错误

有两种方式可以在 PHP 中以异常的方式处理错误: ① PHP 内置的 ErrorException类(也是 Exception 类的子类) 1 <?php 2 function exception_error_handler($errno, $errstr, $errfile, $errline){ 3 throw new ErrorException($errstr, 0, $errno, $errfile, $errline); 4 } 5 6 set_error_handler('exc

PHP 错误与异常 笔记与总结(9)自定义错误处理器

自定义错误处理器更加智能. <?php class myErrorHandler{ //$message:错误信息 //$filename:错误文件名 //$line:错误行号 //$vars:额外信息 public $message = ''; public $filename = ''; public $line = 0; public $vars = array(); protected $_noticeLog = 'D:\practise\php\From\notice\noticeLo

PHP 错误与异常 笔记与总结(16 )自定义异常处理器

可以使用自定义异常处理器来处理所有未捕获的异常(没有用 try/catch 捕获的异常). set_exception_handler():设置一个用户定义的异常处理函数,当一个未捕获的异常发生时所调用函数的名称(回调函数),该函数必须在调用 set_exception_handler() 之前已经定义.该处理函数需要接受一个参数,该参数是一个抛出的异常对象 [例] 1 <?php 2 header('content-type:text/html; charset=utf-8'); 3 head

PHP 错误与异常 笔记与总结(7)将错误日志以邮件方式发送

当系统发生了很严重的问题,需要立刻发送给管理员.可以通过 error_log() 将错误以邮件形式发送到邮箱. 在 php.ini 中设置: sendmail_from = [email protected] 然后设置: sendmail_path = "G:\sendmail\sendmail.exe -t" 其中:G:\sendmail\sendmail.exe 是邮件客户端的地址. 代码: <?php //关闭错误显示 ini_set('display_errors', 0

PHP学习笔记三十三【自定义错误处理器】

<?php //自定义错误处理器 //$errorno 错误号 //$errmes错误信息 //这两个参数是必须的 function my_error($errorno,$errmes) { echo "<font size='5' color='red'>$errorno</font><br/>"; echo "错误信息是:$errmes"; } //必须重写set_error_handler处理器 set_error_h

PHP 错误与异常 笔记与总结(14 )记录和发送异常信息

当发生异常时,把异常信息记录到日志文件中: 1 <?php 2 header('content-type:text/html; charset=utf-8'); 3 class LogException extends Exception{ 4 public function __construct($message = null, $code = 0){ 5 parent::__construct($message, $code); 6 error_log($this->getMessage