(PHP 4 >= 4.0.1, PHP 5, PHP 7)
set_error_handler — �����û��Զ���Ĵ�������
�����û��ĺ��� (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
���¸�ʽ�Ļص���callback����
���Դ��� NULL
���ô������Ĭ��״̬��
���˿��Դ��뺯�����������Դ������ö���Ͷ����������顣
$errno
, string $errstr
[, string $errfile
[, int $errline
[, array $errcontext
]]] ) : boolerrno
errno
�������˴���ļ�����һ�� integer��
errstr
errstr
�������˴������Ϣ����һ�� string��
errfile
errfile
��
�����˷���������ļ�������һ�� string��
errline
errline
��
�����˴��������кţ���һ�� integer��
errcontext
errcontext
��
��һ��ָ�������ʱ����ű�� array��
Ҳ����˵��errcontext
����������������������б��������顣
�û��Ĵ��������Ӧ���Ĵ��������ģ�context����
PHP 7.2.0 ��˲����������ˡ� ���䲻������������
����������� FALSE
���������������������á�
error_types
����error_reporting �� ini �����ܹ����ƴ������ʾһ����
�˲����ܹ��������� error_handler
�Ĵ�����
���û�и����룬
���� error_reporting ��������õģ�
error_handler
������ÿ��������ʱ�����á�
���֮ǰ�ж��������������ظó������Ƶ� string����������õĴ���������� NULL
��
�����ָ����һ����Ч�Ļص�������ͬ���᷵�� NULL
��
���֮ǰ�Ĵ����������һ����ķ������˺����᷵��һ������ͷ���������������(indexed array)��
�汾 | ˵�� |
---|---|
7.2.0 |
errcontext ��������
ʹ�ô˲���ʱ�ᵼ�� E_DEPRECATED ���ѡ�
|
5.5.0 |
error_handler �ɽ��� NULL ��
|
5.2.0 |
�����������뷵�� FALSE ����ʾ
$php_errormsg��
|
Example #1 �� set_error_handler() �� trigger_error() �������
����ʾ��չʾ��ͨ�������������û��Զ���ij����������ڲ��쳣�Ĵ���
<?php
// error handler function
function myErrorHandler($errno, $errstr, $errfile, $errline)
{
if (!(error_reporting() & $errno)) {
// This error code is not included in error_reporting, so let it fall
// through to the standard PHP error handler
return false;
}
switch ($errno) {
case E_USER_ERROR:
echo "<b>My ERROR</b> [$errno] $errstr<br />\n";
echo " Fatal error on line $errline in file $errfile";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />\n";
echo "Aborting...<br />\n";
exit(1);
break;
case E_USER_WARNING:
echo "<b>My WARNING</b> [$errno] $errstr<br />\n";
break;
case E_USER_NOTICE:
echo "<b>My NOTICE</b> [$errno] $errstr<br />\n";
break;
default:
echo "Unknown error type: [$errno] $errstr<br />\n";
break;
}
/* Don't execute PHP internal error handler */
return true;
}
// function to test the error handling
function scale_by_log($vect, $scale)
{
if (!is_numeric($scale) || $scale <= 0) {
trigger_error("log(x) for x <= 0 is undefined, you used: scale = $scale", E_USER_ERROR);
}
if (!is_array($vect)) {
trigger_error("Incorrect input vector, array of values expected", E_USER_WARNING);
return null;
}
$temp = array();
foreach($vect as $pos => $value) {
if (!is_numeric($value)) {
trigger_error("Value at position $pos is not a number, using 0 (zero)", E_USER_NOTICE);
$value = 0;
}
$temp[$pos] = log($scale) * $value;
}
return $temp;
}
// set to the user defined error handler
$old_error_handler = set_error_handler("myErrorHandler");
// trigger some errors, first define a mixed array with a non-numeric item
echo "vector a\n";
$a = array(2, 3, "foo", 5.5, 43.3, 21.11);
print_r($a);
// now generate second array
echo "----\nvector b - a notice (b = log(PI) * a)\n";
/* Value at position $pos is not a number, using 0 (zero) */
$b = scale_by_log($a, M_PI);
print_r($b);
// this is trouble, we pass a string instead of an array
echo "----\nvector c - a warning\n";
/* Incorrect input vector, array of values expected */
$c = scale_by_log("not array", 2.3);
var_dump($c); // NULL
// this is a critical error, log of zero or negative number is undefined
echo "----\nvector d - fatal error\n";
/* log(x) for x <= 0 is undefined, you used: scale = $scale" */
$d = scale_by_log($a, -2.5);
var_dump($d); // Never reached
?>
�������̵���������ڣ�
vector a Array ( [0] => 2 [1] => 3 [2] => foo [3] => 5.5 [4] => 43.3 [5] => 21.11 ) ---- vector b - a notice (b = log(PI) * a) <b>My NOTICE</b> [1024] Value at position 2 is not a number, using 0 (zero)<br /> Array ( [0] => 2.2894597716988 [1] => 3.4341896575482 [2] => 0 [3] => 6.2960143721717 [4] => 49.566804057279 [5] => 24.165247890281 ) ---- vector c - a warning <b>My WARNING</b> [512] Incorrect input vector, array of values expected<br /> NULL ---- vector d - fatal error <b>My ERROR</b> [256] log(x) for x <= 0 is undefined, you used: scale = -2.5<br /> Fatal error on line 35 in file trigger_error.php, PHP 5.2.1 (FreeBSD)<br /> Aborting...<br />