|
復(fù)制代碼 代碼如下:
<?php
//禁止錯(cuò)誤輸出
error_reporting(0);
//設(shè)置錯(cuò)誤處理器
set_error_handler('errorHandler');
register_shutdown_function('fatalErrorHandler');
class Test{
public function index(){
//這里發(fā)生一個(gè)警告錯(cuò)誤,出發(fā)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,
);
//寫(xiě)入錯(cuò)誤日志
//格式 : 時(shí)間 uri | 錯(cuò)誤消息 文件位置 第幾行
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();
////這里發(fā)生一個(gè)警告錯(cuò)誤,被errorHandler 捕獲
$test->index();
//發(fā)生致命錯(cuò)誤,腳本停止運(yùn)行觸發(fā) fatalErrorHandler
$test = new Tesdt();
$test->index();
![]() |
php技術(shù):php異常處理使用示例,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。