PHP中set error handler函数用法小结
set_error_handler()函数设置用户自定义的错误处理函数。该函数用于创建运行时期间的用户自己的错误处理方法。该函数会返回旧的错误处理程序,若失败,则返回null。
下面来看一些例子。
set_error_handler()
PHP从4.1.0开始提供了自定义错误处理句柄的功能函数set_error_handler(),但很少数脚本编写者知道。set_error_handler这个函数可以很好地防止错误路径泄露,当然还有其它更多的作用。
1.可以用来屏蔽错误。出现错误一来会把一些信息暴漏给用户,极有可能成为黑客攻击你网站的工具。二来让用户觉得你的水平很挫。
2.可以记下错误的信息,及时发现一些生产环境的出现的问题。
3.可以做相应的处理,出错的时候可以显示跳转到预先定义好的出错页面,提供更好的用户体验。
4.可以作为调试工具,一些时候必须在生产环境调试一些东西,但又不想影响正在使用的用户。
5.。。。。
set_error_handler的使用方法如下:
viewsourceprint?1stringset_error_handler(callbackerror_handler[,interror_types])
我们利用error_reporting();看到的错误信息包括三个部分,错误信息,错误文件的绝对地址,错误出现的行数。其实还有一个是错误类型。Array([type]=>1[message]=>CalltoundefinedmethodSomeClass::somemedthod()[file]=>/home/zhangy/www/aaaa/stasdf.php[line]=>67),页面的绝对路径最好不要暴露给别人,不然给有些人可称之机,为了杜绝这一点,好多人都会采用,ini_set("display_errors",0);直接把错误信息给屏蔽掉了。这样就不方便了,如果我们要看信息怎么办呢?每次查看的时候,是不是都要改一下代码,或者是改一下apache的配置,在重起一下呢?
php有函数set_error_handler可以解决这个问题
用法如下:
mixedset_error_handler(callback$error_handler[,int$error_types=E_ALL|E_STRICT])
php函数register_shutdown_function也可以解决这个问题
用法如下:
intregister_shutdown_function(string$func)
个人觉得报错函数自己定义,至少有三点好处,
1,不会把文件的绝对路径显示出来,安全些
2,即使真的出现了错误信息,我们可以对错误信息进行处理,让用户也看不到fatalerror这样的东西。用户体验要好
3,项目上线后,有的时候,你还是要帮用户去解决问题,这个时候难免要去修改代码,但是我们又要让错误信息报出来,又不能让用户看到,这个时候,用set_error_handler这样的函数就很爽了。
个人做了一个小测试
<?php error_reporting(0); register_shutdown_function('error_alert'); functionerror_alert() { if(is_null($e=error_get_last())===false) { set_error_handler('errorHandler'); if($e['type']==1){ trigger_error("fatalerror",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"noerror"; } } set_error_handler('errorHandler'); functionerrorHandler($errno,$errstr,$errfile,$errline,$errcontext) { switch($errno){ caseE_USER_ERROR: echo"<b>MyERROR</b>[$errno]$errstr<br/>n"; echo"Fatalerroronline$errlineinfile$errfile"; echo",PHP".PHP_VERSION."(".PHP_OS.")<br/>n"; break; caseE_USER_WARNING: echo"<b>MyWARNING</b>[$errno]$errstr<br/>n"; echo"warningonline$errlineinfile$errfile"; echo",PHP".PHP_VERSION."(".PHP_OS.")<br/>n"; break; caseE_USER_NOTICE: echo"<b>MyNOTICE</b>[$errno]$errstr<br/>n"; echo"noticeonline$errlineinfile$errfile"; echo",PHP".PHP_VERSION."(".PHP_OS.")<br/>n"; break; default: echo"Unknownerrortype:[$errno]$errstr<br/>n"; echo"warningonline$errlineinfile$errfile"; echo",PHP".PHP_VERSION."(".PHP_OS.")<br/>n"; break; } returntrue; } classSomeClass{ publicfunctionsomeMethod(){ } } SomeClass::someMedthod(); $a="asdf"; foreach($aas$d){ echo$d; } ?>
现在我们就用自定义的错误处理把实际路径过滤掉。假设有一个变量$admin,我们是用来判断访问者是否是管理员的(可以通过IP或者登录的用户id来做这个判断)
//admin为管理员的身份判定,true为管理员。
//自定义的错误处理函数一定要有这4个输入变量$errno,$errstr,$errfile,$errline,否则无效。
functionmy_error_handler($errno,$errstr,$errfile,$errline) { //如果不是管理员就过滤实际路径 if(!admin) { $errfile=str_replace(getcwd(),"",$errfile); $errstr=str_replace(getcwd(),"",$errstr); } switch($errno) { caseE_ERROR: echo"ERROR:[ID$errno]$errstr(Line:$errlineof$errfile)n"; echo"程序已经停止运行,请联系管理员。"; //遇到Error级错误时退出脚本 exit; break; caseE_WARNING: echo"WARNING:[ID$errno]$errstr(Line:$errlineof$errfile)n"; break; default: //不显示Notice级的错误 break; } }
这样就自定义了一个错误处理函数,那么怎么把错误的处理交给这个自定义函数呢?
//应用到类 set_error_handler(array(&$this,"appError")); //示例的做法 set_error_handler("my_error_handler");
soeasy,这样,就可以很好地解决安全和调试方便的矛盾了。而且你还可以花点心思,使错误提示更加美观以配合网站的风格。
上面的例子中,我把错误信息关掉了,而用自己的函数处理错误,上面的这个页面会报fatalerror,报出来的错误信息我们是可以利用errorHandler来控制和处理。
好了,总结一下,下面是set_error_handler三种用法:
Php代码
classCallbackClass{ functionCallbackFunction(){ //refersto$this } functionStaticFunction(){ //doesn'treferto$this } } functionNonClassFunction($errno,$errstr,$errfile,$errline){ } //三种方法如下: set_error_handler(‘NonClassFunction');//直接转到一个普通的函数NonClassFunction set_error_handler(array(‘CallbackClass',‘StaticFunction'));//转到CallbackClass类下的静方法StaticFunction $o=&newCallbackClass(); set_error_handler(array($o,‘CallbackFunction'));//转到类的构造函数,其实本质上跟下面的第四条一样。 .$o=newCallbackClass(); //Thefollowingmayalsoproveuseful classCallbackClass{ functionCallbackClass(){ set_error_handler(array(&$this,‘CallbackFunction'));//the&isimportant } functionCallbackFunction(){ //refersto$this } }
下面抽点空给大家介绍单独介绍PHPset_error_handler()函数
定义和用法
set_error_handler()函数设置用户自定义的错误处理函数。
该函数用于创建运行时期间的用户自己的错误处理方法。
该函数会返回旧的错误处理程序,若失败,则返回null。
语法
set_error_handler(error_function,error_types)
参数 描述
error_function 必需。规定发生错误时运行的函数。
error_types 可选。规定在哪个错误报告级别会显示用户定义的错误。默认是"E_ALL"。
提示和注释
提示:如果使用了该函数,会完全绕过标准的PHP错误处理函数,如果必要,用户定义的错误处理程序必须终止(die())脚本。
注释:如果在脚本执行前发生错误,由于在那时自定义程序还没有注册,因此就不会用到这个自定义错误处理程序。
例子
<?php //errorhandlerfunction functioncustomError($errno,$errstr,$errfile,$errline) { echo"<b>Customerror:</b>[$errno]$errstr<br/>"; echo"Erroronline$errlinein$errfile<br/>"; echo"EndingScript"; die(); } //seterrorhandler set_error_handler("customError"); $test=2; //triggererror if($test>1) { trigger_error("Acustomerrorhasbeentriggered"); } ?>
输出:
Customerror:[1024]Acustomerrorhasbeentriggered
Erroronline19inC:/webfolder/test.php
EndingScript