php异常处理使用示例
程序员文章站
2023-11-04 09:28:46
复制代码 代码如下:
<?php
//禁止错误输出
error_reporting(0);
//设置错误处理器
set_error_handler('errorhandler');
register_shutdown_function('fatalerrorhandler');
class test{
public function index(){
//这里发生一个警告错误,出发errorhandler
echo $undefinedvarible;
}
}
function errorhandler($errno,$errstr,$errfile,$errline){
$arr = array(
'['.date('y-m-d h-i-s').']',
'http://www.baidu.com',
'|',
$errstr,
$errfile,
'line:'.$errline,
);
//写入错误日志
//格式 : 时间 uri | 错误消息 文件位置 第几行
error_log(implode(' ',$arr)."\r\n",3,'./test.txt','extra');
echo implode(' ',$arr)."\r\n";
}
复制代码 代码如下:
<?php
//禁止错误输出
error_reporting(0);
//设置错误处理器
set_error_handler('errorhandler');
register_shutdown_function('fatalerrorhandler');
class test{
public function index(){
//这里发生一个警告错误,出发errorhandler
echo $undefinedvarible;
}
}
function errorhandler($errno,$errstr,$errfile,$errline){
$arr = array(
'['.date('y-m-d h-i-s').']',
'http://www.baidu.com',
'|',
$errstr,
$errfile,
'line:'.$errline,
);
//写入错误日志
//格式 : 时间 uri | 错误消息 文件位置 第几行
error_log(implode(' ',$arr)."\r\n",3,'./test.txt','extra');
echo implode(' ',$arr)."\r\n";
}
//捕获fatalerror
function fatalerrorhandler(){
$e = error_get_last();
switch($e['type']){
case e_error:
case e_parse:
case e_core_error:
case e_compile_error:
case e_user_error:
errorhandler($e['type'],$e['message'],$e['file'],$e['line']);
break;
}
}
$test = new test();
////这里发生一个警告错误,被errorhandler 捕获
$test->index();
//发生致命错误,脚本停止运行触发 fatalerrorhandler
$test = new tesdt();
$test->index();