本文實(shí)例講述了PHP自定義錯(cuò)誤處理的方法。分享給大家供大家參考,具體如下:
自定義錯(cuò)誤報(bào)告的處理方式,可以完全繞過(guò)標(biāo)準(zhǔn)的PHP錯(cuò)誤處理函數(shù),這樣就可以按照自己定義的格式打印錯(cuò)誤報(bào)告,或改變錯(cuò)誤報(bào)告打印的位置(標(biāo)準(zhǔn)PHP的錯(cuò)誤報(bào)告是哪里發(fā)生錯(cuò)誤就在發(fā)生位置處顯示)。以下幾種情況可以考慮自定義錯(cuò)誤處理。
★可以記下錯(cuò)誤的信息,及時(shí)發(fā)現(xiàn)一些生產(chǎn)環(huán)境出現(xiàn)的問(wèn)題。
★可以用來(lái)屏蔽錯(cuò)誤。出現(xiàn)錯(cuò)誤會(huì)把一些信息暴漏給用戶,極有可能成為黑客攻擊你網(wǎng)站的工具。
★可以做相應(yīng)的處理,將所有錯(cuò)誤報(bào)告放到腳本最后輸出,或出錯(cuò)時(shí)可以顯示跳轉(zhuǎn)到預(yù)先定義好的出錯(cuò)頁(yè)面,提供更好的用戶體驗(yàn),如果必要,還可以在自定義錯(cuò)誤處理程序中,根據(jù)情況去終止腳本運(yùn)行。
★可以作為調(diào)試工具,一些時(shí)候必須在運(yùn)行環(huán)境時(shí)調(diào)試一些東西,但又不想影響正在使用的用戶。
通常使用set_error_handler()
函數(shù)去設(shè)置用戶自定義的錯(cuò)誤處理函數(shù),該函數(shù)用于創(chuàng)建運(yùn)行時(shí)期間的用戶自己的錯(cuò)誤處理方法,返回舊的錯(cuò)誤處理程序,若失敗,則返回null。該函數(shù)有兩個(gè)參數(shù),其中第一個(gè)參數(shù)是必選的,需要一個(gè)回調(diào)函數(shù),規(guī)定發(fā)生錯(cuò)誤時(shí)運(yùn)行的函數(shù)。這個(gè)回調(diào)函數(shù)一定要聲明4個(gè)參數(shù),否則無(wú)效,按順序分別為“是否存在錯(cuò)誤”、“錯(cuò)誤信息”、“錯(cuò)誤文件”和“錯(cuò)誤行號(hào)”。set_error_handler()
函數(shù)的第二個(gè)參數(shù)則為可選的,規(guī)定現(xiàn)在哪個(gè)錯(cuò)誤報(bào)告級(jí)別會(huì)顯示用戶自定義的錯(cuò)誤。默認(rèn)是“E_ALL”。自定義錯(cuò)誤處理的示例如下所示:
?php
error_reporting(0); //屏蔽程序中的錯(cuò)誤
//定義Error_Handler函數(shù),作為set_error_handler()函數(shù)的第一個(gè)參數(shù)“回調(diào)”
function error_handler($error_level,$error_message,$file,$line){
$EXIT =FALSE;
switch($error_level){
//提醒級(jí)別
case E_NOTICE:
case E_USER_NOTICE:
$error_type = 'Notice';
break;
//警告級(jí)別
case E_WARNING:
case E_USER_WARNING:
$error_type='warning';
break;
//錯(cuò)誤級(jí)別
case E_ERROR:
case E_USER_ERROR:
$error_type='Fatal Error';
$EXIT = TRUE;
break;
//其他未知錯(cuò)誤
default:
$error_type='Unknown';
$EXIT = TRUE;
break;
}
//直接打印錯(cuò)誤信息,也可以寫(xiě)文件,寫(xiě)數(shù)據(jù)庫(kù),反正錯(cuò)誤信息都在這,任你發(fā)落
printf("font color='#FF0000'>b>%s/b>/font>:%s inb>%s/b> on line b>%d/b>br>\n",$error_type, $error_message, $file, $line);
//如果錯(cuò)誤影響到程序的正常執(zhí)行,跳轉(zhuǎn)到友好的錯(cuò)誤提示頁(yè)面
if (TURE==$EXIT){
echo 'script>location = "err.html";/scrpit>';
}
}
//這個(gè)才是關(guān)鍵點(diǎn),把錯(cuò)誤的處理交給error_handle()
set_error_handler('error_handler');
//使用未定義的變量要報(bào)notice的
echo $novar;
//除以0要報(bào)警告的
echo 3/0;
//自定義一個(gè)錯(cuò)誤
trigger_error('Trigger a fatal error',E_USER_ERROR);
?>
本例所有打印的錯(cuò)誤報(bào)告都是按自己定義的格式輸出的,不過(guò)有一點(diǎn),系統(tǒng)直接報(bào)Fatal Error的這里捕獲不到,因?yàn)橄到y(tǒng)不可能把這么重大的錯(cuò)誤教給你處理。遇到這種錯(cuò)誤是必須要解決的,所以系統(tǒng)會(huì)直接終止程序運(yùn)行。使用set_error_handler()
函數(shù)可以很好地解決安全和調(diào)試方便的矛盾,而且你還可以花點(diǎn)心思,使錯(cuò)誤提示更加美觀以配合網(wǎng)站的風(fēng)格。不過(guò)要注意兩點(diǎn)。
①E_ERROR、E_PARSE、E_CORE_ERROR、E_CORE_WARNING、E_COMPILE_ERROR、E_COMPILE_WARNING是不會(huì)被這個(gè)句柄處理的,也就是會(huì)用最原始的方式顯示出來(lái)。不過(guò)出現(xiàn)這些錯(cuò)誤都是編譯或PHP內(nèi)核出錯(cuò),在通常情況下不會(huì)發(fā)生。
②使用set_error_handler()
后,error_reporting()
將會(huì)失效。也就是所有的錯(cuò)誤(除上述的錯(cuò)誤)都會(huì)教給自己定義的函數(shù)處理。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP錯(cuò)誤與異常處理方法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語(yǔ)法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- PHP 自定義錯(cuò)誤處理函數(shù)trigger_error()
- PHP 自定義錯(cuò)誤處理函數(shù)的使用詳解
- php自定義錯(cuò)誤處理用法實(shí)例
- PHP中的錯(cuò)誤處理、異常處理機(jī)制分析
- php一些錯(cuò)誤處理的方法與技巧總結(jié)
- PHP 錯(cuò)誤處理機(jī)制
- php實(shí)現(xiàn)的錯(cuò)誤處理封裝類實(shí)例
- 淺談PHP中的錯(cuò)誤處理和異常處理