Advanced PHP |
data:image/s3,"s3://crabby-images/95bdc/95bdcb934cacec85ca0e5b3fdc03f38193dbd5fd" alt="" |
2025-02-22 |
data:image/s3,"s3://crabby-images/635f7/635f716a38166b9e1463c202af2d9085531820f5" alt="" |
data:image/s3,"s3://crabby-images/75d80/75d808c8162ba31eff47f2649509d4588e385ea5" alt="" |
data:image/s3,"s3://crabby-images/635f7/635f716a38166b9e1463c202af2d9085531820f5" alt=""
28 |
data:image/s3,"s3://crabby-images/47ea0/47ea0beb537dba0e25cdc8cb8ec3d250e35b09fe" alt="" |
data:image/s3,"s3://crabby-images/635f7/635f716a38166b9e1463c202af2d9085531820f5" alt="" |
debug_backtrace() is a new function in PHP 4.3
Custom error handler
<?
function short($str) {
if(strstr($str,'/'))
return substr(strrchr($str,'/'),1);
else return $str;
}
function myErrorHandler($errno,$errstr,$errfile,$errline)
{
echo "$errno: $errstr in ".short($errfile)." at line $errline<br />\n";
echo "Backtrace<br />\n";
$trace = debug_backtrace();
foreach($trace as $ent) {
if(isset($ent['file'])) $ent['file'].':';
if(isset($ent['function'])) {
echo $ent['function'].'(';
if(isset($ent['args'])) {
$args='';
foreach($ent['args'] as $arg) { $args.=$arg.','; }
echo rtrim(short($args),',');
}
echo ') ';
}
if(isset($ent['line'])) echo 'at line '.$ent['line'].' ';
if(isset($ent['file'])) echo 'in '.short($ent['file']);
echo "<br />\n";
}
}
set_error_handler('myErrorHandler');
include 'file2.php';
test2(1,0);
?>
Custom error handler
<?
function test1($b,$a) {
$a/$b;
}
function test2($a,$b) {
test1($b,$a);
}
?>
function short($str) {
if(strstr($str,'/'))
return substr(strrchr($str,'/'),1);
else return $str;
}
function myErrorHandler($errno,$errstr,$errfile,$errline)
{
echo "$errno: $errstr in ".short($errfile)." at line $errline
\n";
echo "Backtrace
\n";
$trace = debug_backtrace();
foreach($trace as $ent) {
if(isset($ent['file'])) $ent['file'].':';
if(isset($ent['function'])) {
echo $ent['function'].'(';
if(isset($ent['args'])) {
$args='';
foreach($ent['args'] as $arg) { $args.=$arg.','; }
echo rtrim(short($args),',');
}
echo ') ';
}
if(isset($ent['line'])) echo 'at line '.$ent['line'].' ';
if(isset($ent['file'])) echo 'in '.short($ent['file']);
echo "
\n";
}
}
set_error_handler('myErrorHandler');
include 'file2.php';
test2(1,0);
?>