php中set-error-handler的用法
set_error_handler() 函數(shù)設(shè)置用戶自定義的錯誤處理函數(shù)。該函數(shù)用于創(chuàng)建運(yùn)行時期間的用戶自己的錯誤處理方法。該函數(shù)會返回舊的錯誤處理程序,若失敗,則返回 null。以下是小編為大家搜索整理php中set_error_handler的用法,希望能給大家?guī)韼椭?更多精彩內(nèi)容請及時關(guān)注我們應(yīng)屆畢業(yè)生考試網(wǎng)!
set_error_handler()
(資料圖片僅供參考)
PHP從4.1.0開始提供了自定義錯誤處理句柄的功能函數(shù)set_error_handler(),但很少數(shù)腳本編寫者知道。set_error_handler這個函數(shù)可以很好地防止錯誤路徑泄露,當(dāng)然還有其它更多的作用。
1.可以用來屏蔽錯誤。 出現(xiàn)錯誤一來會把一些信息暴漏給用戶,極有可能成為黑客攻擊你網(wǎng)站的工具。 二來讓用戶覺得你的水平很挫。
2.可以記下錯誤的信息, 及時發(fā)現(xiàn)一些生產(chǎn)環(huán)境的出現(xiàn)的問題。
3.可以做相應(yīng)的處理, 出錯的時候可以顯示跳轉(zhuǎn)到預(yù)先定義好的出錯頁面,提供更好的用戶體驗。
4.可以作為調(diào)試工具, 一些時候必須在生產(chǎn)環(huán)境調(diào)試一些東西, 但又不想影響正在使用的用戶。
5.。。。。
set_error_handler的使用方法如下:
view sourceprint?1 string set_error_handler ( callback error_handler [, int error_types])
我們利用error_reporting();看到的錯誤信息包括三個部分,錯誤信息,錯誤文件的絕對地址,錯誤出現(xiàn)的行數(shù)。其實(shí)還有一個是錯誤類型。Array ( [type] => 1 [message] => Call to undefined method SomeClass::somemedthod() [file] => /home/zhangy/www/aaaa/stasdf.php [line] => 67 ),頁面的絕對路徑最好不要暴露給別人,不然給有些人可稱之機(jī),為了杜絕這一點(diǎn),好多人都會采用,ini_set("display_errors",0);直接把錯誤信息給屏蔽掉了。這樣就不方便了,如果我們要看信息怎么辦呢?每次查看的時候,是不是都要改一下代碼,或者是改一下apache的配置,在重起一下呢?
php有函數(shù)set_error_handler可以解決這個問題
用法如下:
mixed set_error_handler ( callback $error_handler [, int $error_types = E_ALL | E_STRICT ] )
php函數(shù)register_shutdown_function也可以解決這個問題
用法如下:
int register_shutdown_function ( string $func )
個人覺得報錯函數(shù)自己定義,至少有三點(diǎn)好處,
1,不會把文件的絕對路徑顯示出來,安全些
2,即使真的出現(xiàn)了錯誤信息,我們可以對錯誤信息進(jìn)行處理,讓用戶也看不到fatal error這樣的東西。用戶體驗要好
3,項目上線后,有的時候,你還是要幫用戶去解決問題,這個時候難免要去修改代碼,但是我們又要讓錯誤信息報出來,又不能讓用戶看到,這個時候,用set_error_handler這樣的`函數(shù)就很爽了。
個人做了一個小測試
error_reporting(0);
register_shutdown_function("error_alert");
function error_alert()
{
if(is_null($e = error_get_last()) === false)
{
set_error_handler("errorHandler");
if($e["type"] == 1){
trigger_error("fatal error", E_USER_ERROR);
}elseif($e["type"] == 8){
trigger_error("notice", E_USER_NOTICE);
}elseif($e["type"] == 2){
trigger_error("warning", E_USER_WARNING);
}else{
trigger_error("other", E_USER_OTHER);
}
}else{
echo "no error";
}
}
set_error_handler("errorHandler");
function errorHandler($errno, $errstr, $errfile, $errline,$errcontext)
{
switch ($errno) {
case E_USER_ERROR:
echo "My ERROR [$errno] $errstr
n";
echo " Fatal error on line $errline in file $errfile";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
break;
case E_USER_WARNING:
echo "My WARNING [$errno] $errstr
n";
echo " warning on line $errline in file $errfile";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
break;
case E_USER_NOTICE:
echo "My NOTICE [$errno] $errstr
n";
echo " notice on line $errline in file $errfile";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
break;
default:
echo "Unknown error type: [$errno] $errstr
n";
echo " warning on line $errline in file $errfile";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
n";
break;
}
return true;
}
class SomeClass {
public function someMethod() {
}
}
SomeClass::someMedthod();
$a="asdf";
foreach($a as $d){
echo $d;
}
?>
現(xiàn)在我們就用自定義的錯誤處理把實(shí)際路徑過濾掉。假設(shè)有一個變量$admin,我們是用來判斷訪問者是否是管理員的(可以通過IP或者登錄的用戶id來做這個判斷)
//admin為管理員的身份判定,true為管理員。
//自定義的錯誤處理函數(shù)一定要有這4個輸入變量$errno,$errstr,$errfile,$errline,否則無效。
function my_error_handler($errno,$errstr,$errfile,$errline)
{
//如果不是管理員就過濾實(shí)際路徑
if(!admin)
{
$errfile=str_replace(getcwd(),"",$errfile);
$errstr=str_replace(getcwd(),"",$errstr);
}
switch($errno)
{
case E_ERROR:
echo "ERROR: [ID $errno] $errstr (Line: $errline of $errfile) n";
echo "程序已經(jīng)停止運(yùn)行,請聯(lián)系管理員。";
//遇到Error級錯誤時退出腳本
exit;
break;
case E_WARNING:
echo "WARNING: [ID $errno] $errstr (Line: $errline of $errfile) n";
break;
default:
//不顯示Notice級的錯誤
break;
}
}
這樣就自定義了一個錯誤處理函數(shù),那么怎么把錯誤的處理交給這個自定義函數(shù)呢?
// 應(yīng)用到類
set_error_handler(array(&$this,"appError"));
//示例的做法
set_error_handler("my_error_handler");
so easy,這樣,就可以很好地解決安全和調(diào)試方便的矛盾了。而且你還可以花點(diǎn)心思,使錯誤提示更加美觀以配合網(wǎng)站的風(fēng)格。
上面的例子中,我把錯誤信息關(guān)掉了,而用自己的函數(shù)處理錯誤,上面的這個頁面會報fatal error,報出來的錯誤信息我們是可以利用errorHandler來控制和處理。
好了,總結(jié)一下,下面是 set_error_handler 三種用法:
Php代碼
class CallbackClass {
function CallbackFunction() {
// refers to $this
}
function StaticFunction() {
// doesn’t refer to $this
}
}
function NonClassFunction($errno, $errstr, $errfile, $errline) {
}
// 三種方法如下:
1: set_error_handler(‘NonClassFunction’); // 直接轉(zhuǎn)到一個普通的函數(shù) NonClassFunction
2: set_error_handler(array(‘CallbackClass’, ‘StaticFunction’)); // 轉(zhuǎn)到 CallbackClass 類下的靜方法 StaticFunction
3: $o =& new CallbackClass();
set_error_handler(array($o, ‘CallbackFunction’)); // 轉(zhuǎn)到類的構(gòu)造函數(shù),其實(shí)本質(zhì)上跟下面的第四條一樣。
4. $o = new CallbackClass();
// The following may also prove useful:
class CallbackClass {
function CallbackClass() {
set_error_handler(array(&$this, ‘CallbackFunction’)); // the & is important
}
function CallbackFunction() {
// refers to $this
}
}
詞條內(nèi)容僅供參考,如果您需要解決具體問題
(尤其在法律、醫(yī)學(xué)等領(lǐng)域),建議您咨詢相關(guān)領(lǐng)域?qū)I(yè)人士。