PHP中set error handler函數(shù)用法小結(jié)
set_error_handler() 函數(shù)設(shè)置用戶(hù)自定義的錯(cuò)誤處理函數(shù)。該函數(shù)用于創(chuàng)建運(yùn)行時(shí)期間的用戶(hù)自己的錯(cuò)誤處理方法。該函數(shù)會(huì)返回舊的錯(cuò)誤處理程序,若失敗,則返回 null。
下面來(lái)看一些例子。
set_error_handler()
PHP從4.1.0開(kāi)始提供了自定義錯(cuò)誤處理句柄的功能函數(shù)set_error_handler(),但很少數(shù)腳本編寫(xiě)者知道。set_error_handler這個(gè)函數(shù)可以很好地防止錯(cuò)誤路徑泄露,當(dāng)然還有其它更多的作用。
1.可以用來(lái)屏蔽錯(cuò)誤。 出現(xiàn)錯(cuò)誤一來(lái)會(huì)把一些信息暴漏給用戶(hù),極有可能成為黑客攻擊你網(wǎng)站的工具。 二來(lái)讓用戶(hù)覺(jué)得你的水平很挫。
2.可以記下錯(cuò)誤的信息, 及時(shí)發(fā)現(xiàn)一些生產(chǎn)環(huán)境的出現(xiàn)的問(wèn)題。
3.可以做相應(yīng)的處理, 出錯(cuò)的時(shí)候可以顯示跳轉(zhuǎn)到預(yù)先定義好的出錯(cuò)頁(yè)面,提供更好的用戶(hù)體驗(yàn)。
4.可以作為調(diào)試工具, 一些時(shí)候必須在生產(chǎn)環(huán)境調(diào)試一些東西, 但又不想影響正在使用的用戶(hù)。
5.。。。。
set_error_handler的使用方法如下:
view sourceprint?1 string set_error_handler ( callback error_handler [, int error_types])
我們利用error_reporting();看到的錯(cuò)誤信息包括三個(gè)部分,錯(cuò)誤信息,錯(cuò)誤文件的絕對(duì)地址,錯(cuò)誤出現(xiàn)的行數(shù)。其實(shí)還有一個(gè)是錯(cuò)誤類(lèi)型。Array ( [type] => 1 [message] => Call to undefined method SomeClass::somemedthod() [file] => /home/zhangy/www/aaaa/stasdf.php [line] => 67 ),頁(yè)面的絕對(duì)路徑最好不要暴露給別人,不然給有些人可稱(chēng)之機(jī),為了杜絕這一點(diǎn),好多人都會(huì)采用,ini_set("display_errors",0);直接把錯(cuò)誤信息給屏蔽掉了。這樣就不方便了,如果我們要看信息怎么辦呢?每次查看的時(shí)候,是不是都要改一下代碼,或者是改一下apache的配置,在重起一下呢?
php有函數(shù)set_error_handler可以解決這個(gè)問(wèn)題
用法如下:
mixed set_error_handler ( callback $error_handler [, int $error_types = E_ALL | E_STRICT ] )
php函數(shù)register_shutdown_function也可以解決這個(gè)問(wèn)題
用法如下:
int register_shutdown_function ( string $func )
個(gè)人覺(jué)得報(bào)錯(cuò)函數(shù)自己定義,至少有三點(diǎn)好處,
1,不會(huì)把文件的絕對(duì)路徑顯示出來(lái),安全些
2,即使真的出現(xiàn)了錯(cuò)誤信息,我們可以對(duì)錯(cuò)誤信息進(jìn)行處理,讓用戶(hù)也看不到fatal error這樣的東西。用戶(hù)體驗(yàn)要好
3,項(xiàng)目上線后,有的時(shí)候,你還是要幫用戶(hù)去解決問(wèn)題,這個(gè)時(shí)候難免要去修改代碼,但是我們又要讓錯(cuò)誤信息報(bào)出來(lái),又不能讓用戶(hù)看到,這個(gè)時(shí)候,用set_error_handler這樣的函數(shù)就很爽了。
個(gè)人做了一個(gè)小測(cè)試
<?php 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 "<b>My ERROR</b> [$errno] $errstr<br />n"; echo " Fatal error on line $errline in file $errfile"; echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />n"; break; case E_USER_WARNING: echo "<b>My WARNING</b> [$errno] $errstr<br />n"; echo " warning on line $errline in file $errfile"; echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />n"; break; case E_USER_NOTICE: echo "<b>My NOTICE</b> [$errno] $errstr<br />n"; echo " notice on line $errline in file $errfile"; echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />n"; break; default: echo "Unknown error type: [$errno] $errstr<br />n"; echo " warning on line $errline in file $errfile"; echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />n"; break; } return true; } class SomeClass { public function someMethod() { } } SomeClass::someMedthod(); $a="asdf"; foreach($a as $d){ echo $d; } ?>
現(xiàn)在我們就用自定義的錯(cuò)誤處理把實(shí)際路徑過(guò)濾掉。假設(shè)有一個(gè)變量$admin,我們是用來(lái)判斷訪問(wèn)者是否是管理員的(可以通過(guò)IP或者登錄的用戶(hù)id來(lái)做這個(gè)判斷)
//admin為管理員的身份判定,true為管理員。
//自定義的錯(cuò)誤處理函數(shù)一定要有這4個(gè)輸入變量$errno,$errstr,$errfile,$errline,否則無(wú)效。
function my_error_handler($errno,$errstr,$errfile,$errline) { //如果不是管理員就過(guò)濾實(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)行,請(qǐng)聯(lián)系管理員。"; //遇到Error級(jí)錯(cuò)誤時(shí)退出腳本 exit; break; case E_WARNING: echo "WARNING: [ID $errno] $errstr (Line: $errline of $errfile) n"; break; default: //不顯示Notice級(jí)的錯(cuò)誤 break; } }
這樣就自定義了一個(gè)錯(cuò)誤處理函數(shù),那么怎么把錯(cuò)誤的處理交給這個(gè)自定義函數(shù)呢?
// 應(yīng)用到類(lèi) set_error_handler(array(&$this,"appError")); //示例的做法 set_error_handler("my_error_handler");
so easy,這樣,就可以很好地解決安全和調(diào)試方便的矛盾了。而且你還可以花點(diǎn)心思,使錯(cuò)誤提示更加美觀以配合網(wǎng)站的風(fēng)格。
上面的例子中,我把錯(cuò)誤信息關(guān)掉了,而用自己的函數(shù)處理錯(cuò)誤,上面的這個(gè)頁(yè)面會(huì)報(bào)fatal error,報(bào)出來(lái)的錯(cuò)誤信息我們是可以利用errorHandler來(lái)控制和處理。
好了,總結(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) { } // 三種方法如下: set_error_handler(‘NonClassFunction'); // 直接轉(zhuǎn)到一個(gè)普通的函數(shù) NonClassFunction set_error_handler(array(‘CallbackClass', ‘StaticFunction')); // 轉(zhuǎn)到 CallbackClass 類(lèi)下的靜方法 StaticFunction $o =& new CallbackClass(); set_error_handler(array($o, ‘CallbackFunction')); // 轉(zhuǎn)到類(lèi)的構(gòu)造函數(shù),其實(shí)本質(zhì)上跟下面的第四條一樣。 . $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 } }
下面抽點(diǎn)空給大家介紹單獨(dú)介紹PHP set_error_handler() 函數(shù)
定義和用法
set_error_handler() 函數(shù)設(shè)置用戶(hù)自定義的錯(cuò)誤處理函數(shù)。
該函數(shù)用于創(chuàng)建運(yùn)行時(shí)期間的用戶(hù)自己的錯(cuò)誤處理方法。
該函數(shù)會(huì)返回舊的錯(cuò)誤處理程序,若失敗,則返回 null。
語(yǔ)法
set_error_handler(error_function,error_types)
參數(shù) 描述
error_function 必需。規(guī)定發(fā)生錯(cuò)誤時(shí)運(yùn)行的函數(shù)。
error_types 可選。規(guī)定在哪個(gè)錯(cuò)誤報(bào)告級(jí)別會(huì)顯示用戶(hù)定義的錯(cuò)誤。默認(rèn)是 "E_ALL"。
提示和注釋
提示:如果使用了該函數(shù),會(huì)完全繞過(guò)標(biāo)準(zhǔn)的 PHP 錯(cuò)誤處理函數(shù),如果必要,用戶(hù)定義的錯(cuò)誤處理程序必須終止 (die() ) 腳本。
注釋?zhuān)喝绻谀_本執(zhí)行前發(fā)生錯(cuò)誤,由于在那時(shí)自定義程序還沒(méi)有注冊(cè),因此就不會(huì)用到這個(gè)自定義錯(cuò)誤處理程序。
例子
<?php //error handler function function customError($errno, $errstr, $errfile, $errline) { echo "<b>Custom error:</b> [$errno] $errstr<br />"; echo " Error on line $errline in $errfile<br />"; echo "Ending Script"; die(); } //set error handler set_error_handler("customError"); $test=2; //trigger error if ($test>1) { trigger_error("A custom error has been triggered"); } ?>
輸出:
Custom error: [1024] A custom error has been triggered
Error on line 19 in C:/webfolder/test.php
Ending Script
- php實(shí)現(xiàn)的簡(jiǎn)單日志寫(xiě)入函數(shù)
- PHP調(diào)試函數(shù)和日志記錄函數(shù)分享
- php基于自定義函數(shù)記錄log日志方法
- PHP 日志縮略名的創(chuàng)建函數(shù)代碼
- php error_log 函數(shù)的使用
- PHP error_log()將錯(cuò)誤信息寫(xiě)入一個(gè)文件(定義和用法)
- PHP中error_log()函數(shù)的使用方法
- PHP Error與Logging函數(shù)的深入理解
- 記錄PHP錯(cuò)誤日志 display_errors與log_errors的區(qū)別
- PHP中error_reporting()函數(shù)的用法(修改PHP屏蔽錯(cuò)誤)
- PHP函數(shù)之error_reporting(E_ALL ^ E_NOTICE)詳細(xì)說(shuō)明
- php日志函數(shù)error_log用法實(shí)例分析
相關(guān)文章
Yii2 rbac權(quán)限控制操作步驟實(shí)例教程
這篇文章主要介紹了Yii2 rbac權(quán)限控制操作步驟實(shí)例教程的相關(guān)資料,需要的朋友可以參考下2016-04-04thinkPHP框架可添加js事件的分頁(yè)類(lèi)customPage.class.php完整實(shí)例
這篇文章主要介紹了thinkPHP框架可添加js事件的分頁(yè)類(lèi)customPage.class.php,以完整實(shí)例形式給出了分頁(yè)類(lèi)customPage.class.php的實(shí)現(xiàn)代碼并分析了ajax動(dòng)態(tài)加載數(shù)據(jù),設(shè)置分頁(yè)鏈接等功能,需要的朋友可以參考下2017-03-03tp5修改(實(shí)現(xiàn)即點(diǎn)即改)
今天小編就為大家分享一篇tp5修改(實(shí)現(xiàn)即點(diǎn)即改),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10thinkphp驗(yàn)證碼顯示不出來(lái)的解決方法
這篇文章主要介紹了thinkphp驗(yàn)證碼顯示不出來(lái)的解決方法,需要的朋友可以參考下2014-03-03簡(jiǎn)單談?wù)凱HP面向?qū)ο笾畼?biāo)識(shí)對(duì)象
下面小編就為大家?guī)?lái)一篇簡(jiǎn)單談?wù)凱HP面向?qū)ο笾畼?biāo)識(shí)對(duì)象。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06Laravel框架實(shí)現(xiàn)利用中間件進(jìn)行操作日志記錄功能
這篇文章主要介紹了Laravel框架實(shí)現(xiàn)利用中間件進(jìn)行操作日志記錄功能,結(jié)合實(shí)例形式分析了Laravel框架中間件的創(chuàng)建、引入以及使用中間件進(jìn)行操作日志記錄功能的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-06-06Zend Framework教程之Zend_Config_Xml用法分析
這篇文章主要介紹了Zend Framework教程之Zend_Config_Xml用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Zend_Config_Xml的功能,使用方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-03-03